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 3418. 机器人可以获得的最大金币数 中等
leetcode
workflower5 小时前
用硬件换时间”与“用算法降成本”之间的博弈
人工智能·算法·安全·集成测试·无人机·ai编程
重生之我是Java开发战士7 小时前
【动态规划】简单多状态dp问题:按摩师,打家劫舍,删除并获得点数,粉刷房子,买卖股票的最佳时机
算法·动态规划·哈希算法
KAU的云实验台8 小时前
单/多UAV、静/动态路径规划,基于PlatEMO平台的带约束多目标优化 本文核心内容:
算法·matlab·无人机
Liangwei Lin8 小时前
洛谷 P1807 最长路
数据结构·算法
会编程的土豆8 小时前
【数据结构与算法】二叉树从建立开始
数据结构·c++·算法
_日拱一卒8 小时前
LeetCode:最大子数组和
数据结构·算法·leetcode
计算机安禾8 小时前
【数据结构与算法】第22篇:线索二叉树(Threaded Binary Tree)
c语言·开发语言·数据结构·学习·算法·链表·visual studio code
算法鑫探9 小时前
解密2025数字密码:数位统计之谜
c语言·数据结构·算法·新人首发