LeetCode热题100-验证二叉搜索树

给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

有效 二叉搜索树定义如下:

  • 节点的左子树只包含严格小于当前节点的数。
  • 节点的右子树只包含 严格大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

示例 1:

复制代码
输入:root = [2,1,3]
输出:true

逻辑

  • 初始根节点范围:(-∞, +∞)
  • 遍历左孩子:最大值收缩为当前节点值
  • 遍历右孩子:最小值收缩为当前节点值
  • 一旦越界,不是合法 BST
python 复制代码
class Solution:
    def isValidBST(self, root: Optional[TreeNode]) -> bool:
        def check(node, low, high):
            if not node:
                return True
            if node.val <= low or node.val >= high:
                return False
            return check(node.left, low, node.val) and check(node.right, node.val, high)
        
        return check(root, float("-inf"), float("inf"))
相关推荐
小欣加油23 分钟前
Leetcode31 下一个排列
数据结构·c++·算法·leetcode·职场和发展
_日拱一卒39 分钟前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
无限进步_40 分钟前
【Linux】进程状态、僵尸与孤儿、进程调度
linux·运维·服务器·开发语言·数据结构·算法
郝学胜-神的一滴41 分钟前
力扣 662 :二叉树最大宽度
java·数据结构·c++·python·算法·leetcode·职场和发展
2301_7644413343 分钟前
基于Stackelberg博弈的分散式库存模型
python·算法·数学建模
qq 13740186111 小时前
医用无菌屏障系统加速老化标准解读:ASTM F1980-2016 全解析
人工智能·算法·加速老化·包装测试·astm·医疗器械包装·无菌屏障系统
wayz111 小时前
Overlap:SLOPE(线性回归斜率)技术指标详解
算法·金融·数据分析·回归·线性回归·量化交易·特征工程
点云兔子1 小时前
舱口检测:从点云到矩形定位的射线投影算法
opencv·算法·点云·舱口检测
小欣加油1 小时前
leetcode169 多数元素
数据结构·c++·算法·leetcode·职场和发展
wayz111 小时前
Momentum:RVGI(相对活力指数)技术指标详解
算法·金融·数据分析·量化交易·特征工程