The left subtree of a node contains only nodes with keys
less than
the node's key.
The right subtree of a node contains only nodes with keys
greater than
the node's key.
Both the left and right subtrees must also be binary search trees.
Example 1:
Input:
2
/ \
1 3
Output:
true
Example 2:
5
/ \
1 4
/ \
3 6
Output:
false
Explanation:
The input is: [5,1,4,null,null,3,6]. The root node's value
is 5 but its right child's value is 4.
分析
中序遍历 while
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution(object):
def isValidBST(self, root):
"""
:type root: TreeNode
:rtype: bool
"""
stack = []
cur = root
prev = None
while cur or stack:
while cur:
stack.append(cur)
cur = cur.left
cur = stack.pop()
if prev and cur.val<=prev.val:
return False
prev = cur
cur = cur.right
return True
dfs
用root.val 传入dfs参数,作为最大值最小值
float('-inf'),float('inf')
# Definition for a binary tree node.
# class TreeNode(object):
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution(object):
def isValidBST(self, root):
"""
:type root: TreeNode
:rtype: bool
"""
return self.helper(root,float('-inf'),float('inf'))
def helper(self,root,minn,maxx):
if not root:
return True
if root.val >= maxx or root.val <= minn:
return False
return self.helper(root.left,minn,root.val) and self.helper(root.right,root.val,maxx)