hot 100 98. 验证二叉搜索树

验证二叉搜索树


问题描述

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

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

节点的左子树只包含 严格小于 当前节点的数。

节点的右子树只包含 严格大于 当前节点的数。

所有左子树和右子树自身必须也是二叉搜索树。


样例输入

cpp 复制代码
root = [5,1,4,null,null,3,6]

样例输出

cpp 复制代码
false

评测用例规模与约定

树中节点数目范围在[1, 10^4] 内

-2^31 <= Node.val <= 2^31 - 1


解析

依旧老朋友递归遍历左右子树看是否符合二叉搜索树规则,

如果节点的值比最大的还大或者比最小的还小肯定不行。


参考程序

cpp 复制代码
class Solution {
public:
    bool solve(TreeNode* root,long a,long b){
        if(root==nullptr)return true;
        if(root->val>=b||root->val<=a)return false;
        return(solve(root->left,a,root->val)&&solve(root->right,root->val,b));
    }
    bool isValidBST(TreeNode* root) {
        return solve(root,LONG_MIN,LONG_MAX);
    }
};

难度等级

⭐️⭐️⭐️(1~10星)

以个人刷题整理为目的,如若侵权,请联系删除~

相关推荐
黎梨梨梨_3 小时前
C++入门基础(下)(重载,引用,inline,nullptr)
开发语言·c++·算法
Jasmine_llq3 小时前
《B4411 [GESP202509 二级] 优美的数字》
算法·暴力枚举算法·逐位校验算法·统一数位判断算法·条件计数算法·自定义函数判断算法
做时间的朋友。3 小时前
小华地图寻宝
算法
贾斯汀玛尔斯3 小时前
每天学一个算法--单调栈(Monotonic Stack)
运维·服务器·算法
ZPC82103 小时前
ROS2 速度远快于 UDP的完整方案(同机节点)
人工智能·算法·计算机视觉·机器人
khalil10203 小时前
代码随想录算法训练营Day-34动态规划03 | 01背包问题 二维、01背包问题 一维、416. 分割等和子集
数据结构·c++·算法·leetcode·动态规划·背包问题·01背包
华清远见IT开放实验室3 小时前
AI 算法核心知识清单(深度实战版2)
人工智能·深度学习·算法·机器学习·ai·模型训练
点云侠4 小时前
隧道中线提取的优化方法
c++·算法·最小二乘法
圣保罗的大教堂4 小时前
leetcode 3761. 镜像对之间最小绝对距离 中等
leetcode
minji...4 小时前
Linux 线程同步与互斥(五) 日志,线程池
linux·运维·服务器·开发语言·c++·算法