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

Leetcode Validate Binary Search Tree

Leetcode 98. Validate Binary Search Tree