码迷,mamicode.com
首页 > 编程语言 > 详细

[leetcode] Validate Binary Search Tree (检验是否为二叉查找树) Python

时间:2014-09-18 11:24:13      阅读:379      评论:0      收藏:0      [点我收藏+]

标签:des   style   blog   color   io   ar   strong   div   sp   

Given a binary tree, determine if it is a valid binary search tree (BST).

Assume a BST is defined as follows:

  • 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.

leetcode已经给出了二叉查找树的定义了。

 

class Solution:
    # @param root, a tree node
    # @return a boolean
    def isValidBST(self, root):
        if root is None:
            return True
        return self.helper(root,-99999,999999)
    
    # left ~ right 是node的取值范围
    def helper(self,root,left,right):
        
        if root is None:
            return True
        if root.val <= left or root.val >=right:
            #超出范围
            return False
        return self.helper(root.left,left,root.val) and self.helper(root.right,root.val,right)

 

找到画图工具后我再来更新部分的图

 

[leetcode] Validate Binary Search Tree (检验是否为二叉查找树) Python

标签:des   style   blog   color   io   ar   strong   div   sp   

原文地址:http://www.cnblogs.com/zhidan/p/3978648.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!