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);
    }
}
相关推荐
CoovallyAIHub18 分钟前
Pipecat:构建实时语音 AI Agent 的开源编排框架,500ms 级端到端延迟
深度学习·算法·计算机视觉
灰色小旋风22 分钟前
力扣13 罗马数字转整数
数据结构·c++·算法·leetcode
2301_8101609527 分钟前
C++与物联网开发
开发语言·c++·算法
cm65432031 分钟前
基于C++的操作系统开发
开发语言·c++·算法
ArturiaZ33 分钟前
【day57】
开发语言·c++·算法
CoovallyAIHub35 分钟前
Energies | 8版YOLO对8版Transformer实测光伏缺陷检测,RF-DETR-Small综合胜出
深度学习·算法·计算机视觉
Emberone42 分钟前
排序:万物皆有序
算法·排序算法
其实秋天的枫44 分钟前
2025年12月英语六级真题及答案解析完整版(第一、二、三套全PDF)
经验分享·算法
2401_874732531 小时前
C++并发编程中的死锁避免
开发语言·c++·算法
2301_792308251 小时前
C++编译期数学计算
开发语言·c++·算法