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星)

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

相关推荐
liu-yonggang2 小时前
ROS2 性能优化与功能增强方案
大数据·算法·性能优化
Alsian2 小时前
Day41 TensorBoard
人工智能·算法·机器学习
美好的事情能不能发生在我身上2 小时前
Leetcode热题100中的:矩阵专题
算法·leetcode·矩阵
Tisfy2 小时前
LeetCode 3296.移山所需的最少秒数:优先队列
算法·leetcode·题解·优先队列·模拟
㓗冽2 小时前
龟兔赛跑预测-进阶题6
算法
云泽8082 小时前
蓝桥杯算法精讲:贪心算法的简单应用与题解
算法·贪心算法·蓝桥杯
程序员夏末2 小时前
【LeetCode | 第四篇】算法笔记
笔记·算法·leetcode
DeepModel2 小时前
【概率分布】多项分布详解
算法·概率论
_日拱一卒3 小时前
LeetCode(力扣):只出现一次的数字
java·数据结构·算法