hot100-41验证二叉搜索树

一、题目

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

二、思路

1、函数的作用判断该二叉树是否是二叉搜索树。二叉搜索树的左子树所有节点的值必须严格小于它,右子树中所有节点的值必须严格大于它。(是整个左/右子树,不仅仅是左右子节点)。

所以,需要每个节点都有一个合法区间,根节点的合法区间是 (-∞, +∞),左子节点的合法区间是 (-∞, root.val),右子节点的合法区间是 (root.val, +∞)。

每往下一层,合法区间就会被进一步限制,递归时必须传递上下界(min和max),isValidBST

(TreeNode root) 只接受一个参数(根节点),所以需要写一个辅助函数,传递min和max信息。

2、二叉搜索树特点

1)每个节点都有一个数据域,且所有节点的数据域互不相同。

2)左子树的所有节点的值都小于根节点的值。

3)右子树的所有节点的值都大于根节点的值。

4)左子树和右子树也分别为二叉搜索树。

5)中序遍历为升序数组。

三、代码

java 复制代码
class Solution {
    public boolean isValidBST(TreeNode root) {
        return isValidBST(root,Long.MIN_VALUE,Long.MAX_VALUE);
    }
    public boolean isValidBST(TreeNode root,long min,long max){
        if(root == null) return true;
        if(root.val <= min || root.val >= max) return false;
        return isValidBST(root.left,min,root.val) && isValidBST(root.right,root.val,max);
    }
}
相关推荐
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮1 天前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 天前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove1 天前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung1 天前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了1 天前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL1 天前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰1 天前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商1 天前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
foundbug9991 天前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab