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

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

相关推荐
_深海凉_4 分钟前
LeetCode热题100-对称二叉树
算法·leetcode·职场和发展
瑞华丽PLM8 分钟前
瑞华丽工业软件研发效能全景展示
人工智能·算法·cae·工业软件·国产软件·瑞华丽plm·瑞华丽
运筹vivo@12 分钟前
两数之和(leetcode)
算法·leetcode·职场和发展
吃好睡好便好19 分钟前
在Matlab中绘制二维等高线图
开发语言·人工智能·学习·算法·matlab
Mr_pyx23 分钟前
LeetCode Hot 100 - 最长递增子序列完全题解
算法·leetcode·职场和发展
Mr_pyx25 分钟前
LeetCode Hot 100 - 爬楼梯完全题解
算法·动态规划
z2005093029 分钟前
今日算法: 二叉搜索树
算法
蝈理塘(/_\)大怨种32 分钟前
快速排序的递归与非递归实现
数据结构·算法
吴可可12341 分钟前
用Bulge保持多段线圆弧连续性
算法·c#
qq_296553271 小时前
矩阵逆时针旋转90度:三种解法从入门到精通
数据结构·python·算法·面试·矩阵