题解 | #判断是不是二叉搜索树#

判断是不是二叉搜索树

http://www.nowcoder.com/practice/a69242b39baf45dea217815c7dedb52b

解题思路:

  1. 对于二叉搜索树来说,应该每个结点的值大于他的左子树的值,小于他的右子树的值
  2. 兵分两路走,然后在走的过程中不断的判断,这棵树满不满足二叉搜索树
  3. return 递归函数:会一直往下面找,直到产生想要的那个结果
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param root TreeNode类 
# @return bool布尔型
#
class Solution:
    def isValidBST(self , root: TreeNode) -> bool:
        # write code here
        return self.search(root, float('-inf'), float('inf'))
    def search(self, root, left, right):
        if not root:
            return True
        if root.val < left or root.val > right:
            return False
        return self.search(root.left, left, root.val) and self.search(root.right, root.val, right)
全部评论

相关推荐

01-10 22:44
已编辑
门头沟学院 Java
不知道怎么取名字_:其实好多都是这样,好多公司除创业的外,都是有自己的那一套了,新项目也会在基于老项目适配,但是这种要是能把人家项目的代码全部看完,自己整体出架构方案,使用的技术,那就收获很大的
有深度的简历长什么样?
点赞 评论 收藏
分享
01-08 12:01
门头沟学院 Java
冰炸橙汁_不做oj版:不接好运
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务