【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);
    }
};
相关推荐
代码中介商2 小时前
C++ STL 容器完全指南(二):vector 深入与 stringstream 实战
开发语言·c++
YUDAMENGNIUBI3 小时前
day20_逻辑回归
算法·机器学习·逻辑回归
澈2077 小时前
C++并查集:高效解决连通性问题
java·c++·算法
郝学胜-神的一滴8 小时前
Qt 入门 01-01:从零基础到商业级客户端实战
开发语言·c++·qt·程序人生·软件构建
宏笋8 小时前
C++ thread的detach()方法详解
c++
旖-旎8 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM9 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮9 小时前
二叉树核心概念与Java实现详解
数据结构·算法
大卡片10 小时前
C++的基础知识点
开发语言·c++
米罗篮10 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程