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);
    }
}
相关推荐
YuTaoShao13 小时前
【LeetCode 每日一题】712. 两个字符串的最小ASCII删除和——(解法一)记忆化搜索
算法·leetcode·职场和发展
知乎的哥廷根数学学派13 小时前
基于物理信息嵌入与多维度约束的深度学习地基承载力智能预测与可解释性评估算法(以模拟信号为例,Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习
古城小栈13 小时前
Rust 丰富&好用的 格式化语法
前端·算法·rust
AuroraWanderll13 小时前
类和对象(六)--友元、内部类与再次理解类和对象
c语言·数据结构·c++·算法·stl
leaves falling13 小时前
c语言-给定两个数,求这两个数的最大公约数
数据结构·算法
SamtecChina202313 小时前
Electronica现场演示 | 严苛环境下的56G互连
大数据·网络·人工智能·算法·计算机外设
Tim_1013 小时前
【C++入门】05、复合类型-数组
开发语言·c++·算法
jikiecui13 小时前
信奥崔老师:三目运算 (Ternary Operator)
数据结构·c++·算法
无限进步_13 小时前
【C语言&数据结构】另一棵树的子树:递归思维的双重奏
c语言·开发语言·数据结构·c++·算法·github·visual studio