【Hot 100 刷题计划】 LeetCode 98. 验证二叉搜索树 | C++ 指针边界法

LeetCode 98. 验证二叉搜索树

📌 题目描述

题目级别:中等

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

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

  • 节点的左子树只包含 严格小于 当前节点的数。
  • 节点的右子树只包含 严格大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

💡 破题思路:区间约束法 (自顶向下)

验证 BST 的最大陷阱是:不能只判断当前节点和它的左右孩子

比如 [5,4,6,null,null,3,7],节点 6 的左孩子是 3,虽然 3 < 6 局部成立,但 3 身处根节点 5 的右子树中,它必须大于 5

因此,我们需要自顶向下地传递一个合法区间 (min, max)

  1. 根节点的区间是 (-∞, +∞)
  2. 往左子树走时,当前节点的值就成了左子树的上限
  3. 往右子树走时,当前节点的值就成了右子树的下限

高光技巧(指针代替数值):

很多解法用 LONG_MIN 来初始化极小值,但如果节点值本身就是 long long 类型的下界呢?

最优的写法是使用 TreeNode* 指针来表示边界。如果指针为空,表示没有边界限制;如果指针有值,直接解引用比较。优雅且绝对不会溢出。


💻 C++ 代码实现 (指针边界版)

cpp 复制代码
class Solution {
public:
    bool isValidBST(TreeNode* root) {
        // 初始状态:上下界均无限制 (nullptr)
        return dfs(root, nullptr, nullptr);
    }

    bool dfs(TreeNode* root, TreeNode* minN, TreeNode* maxN)
    {
        // 走到空节点,说明没有违反规则
        if (!root) return true;
        
        // 如果下界存在,且当前值没有严格大于下界,判负
        // 如果上界存在,且当前值没有严格小于上界,判负
        if ((minN && root->val <= minN->val) || (maxN && root->val >= maxN->val)) 
            return false;

        // 向左子树递归:下界不变,上界更新为当前节点
        // 向右子树递归:下界更新为当前节点,上界不变
        return dfs(root->left, minN, root) && dfs(root->right, root, maxN);
    }
};
相关推荐
Billlly17 小时前
莫比乌斯反演学习笔记
算法
fqbqrr17 小时前
2606C++,方便的调试类
c++
我不是懒洋洋17 小时前
从零实现一个RPC框架:远程调用与服务治理
c++
困意少年17 小时前
从统一初始化到移动语义:C++11 为什么是现代 C++ 的起点
c++
stolentime17 小时前
CF2066D1 Club of Young Aircraft Builders (easy version)题解
c++·算法·动态规划·组合数学
Dillon Dong17 小时前
【风电控制】高低穿现场失败的原因分析——算法简单但工程复杂
算法·变流器·风电控制·dfig
Jun62618 小时前
QT(1)-C/C++库生成和调用
c语言·开发语言·c++·qt
小欣加油18 小时前
leetcode41 缺失的第一个正数
数据结构·c++·算法·leetcode
I Promise3418 小时前
智驾APA_HPA可行驶区域检测算法工程师面试问题整理可参考
算法·面试·职场和发展
智者知已应修善业18 小时前
【51单片机按键控制1分钟正计时倒计时暂停复位】2024-1-2
c++·经验分享·笔记·算法·51单片机