LeetCode Validate Binary Search Tree
Posted gavinfish
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode Validate Binary Search Tree相关的知识,希望对你有一定的参考价值。
LeetCode解题之Validate Binary Search Tree
原题
判断一棵二叉搜索树是否有效。有效是指每个节点的值大于左节点,小于右节点(如果有对应节点的话),且它的左节点和右节点也满足这种条件。
注意点:
- 无
例子:
输入:
2
/ \\
1 3
输出: True
解题思路
在 Binary Tree Inorder Traversal 的基础上进行了修改。在树的中序遍历中,节点的顺序是左节点、根节点、右节点。这就说明一棵二叉搜索树要符合要求时,它的中序遍历序列一定是递增的。如果在中序遍历中出现前面的节点大于后面的节点,则说明不符合要求。
AC源码
# 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 = []
curr = root
prev = None
while curr or stack:
while curr:
stack.append(curr)
curr = curr.left
if stack:
curr = stack.pop()
if prev and curr.val <= prev.val:
return False
prev = curr
curr = curr.right
return True
if __name__ == "__main__":
None
欢迎查看我的Github (https://github.com/gavinfish/LeetCode-Python) 来获得相关源码。
以上是关于LeetCode Validate Binary Search Tree的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode -- Validate Binary Search Tree
LeetCode98. Validate Binary Search Tree
[LeetCode_98]Validate Binary Search Tree
LeetCode Validate Binary Search Tree