news 2026/4/16 14:30:11

day146—递归—验证二叉搜索树(LeetCode-98)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day146—递归—验证二叉搜索树(LeetCode-98)

题目描述

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

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

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

示例 1:

输入:root = [2,1,3]输出:true

示例 2:

输入:root = [5,1,4,null,null,3,6]输出:false解释:根节点的值是 5 ,但是右子节点的值是 4 。

提示:

  • 树中节点数目范围在[1, 104]
  • -231 <= Node.val <= 231 - 1

解决方案:

这段代码的核心功能是判断一棵二叉树是否为有效的二叉搜索树(BST)(满足:左子树所有节点值 < 当前节点值 < 右子树所有节点值,且左右子树也必须是 BST),采用「递归 + 上下界约束」的思路逐节点校验,时间复杂度O(n)n为节点数),空间复杂度O(h)h为树的高度),是该问题的经典最优解法。

核心逻辑

代码的核心是为每个节点设定严格的数值上下界,递归校验节点值是否在合法区间内,同时将约束传递给左右子树:

  1. 递归辅助函数f:参数为当前节点node、当前节点值的下界l(左边界)、上界r(右边界):
    • 边界条件:空节点直接返回true(空树是合法的 BST);
    • 当前节点值校验:取出节点值dx,若dx小于等于下界l或大于等于上界r,说明违反 BST 规则,返回false
    • 递归校验子树:
      • 左子树的上下界更新为(l, dx)(左子树所有节点值必须 < 当前节点值dx);
      • 右子树的上下界更新为(dx, r)(右子树所有节点值必须 > 当前节点值dx);
      • 只有左右子树都合法,才返回true
  2. 主函数isValidBST
    • 调用辅助函数时,为根节点设定初始上下界:下界为LLONG_MIN(long long 类型的最小值)、上界为LLONG_MAX(long long 类型的最大值),覆盖所有整数范围,避免数值溢出;
    • 最终返回辅助函数的校验结果。

总结

  1. 核心思路:通过递归传递上下界约束,而非仅对比当前节点与左右子节点(避免 “仅局部满足、整体不满足” 的错误);
  2. 关键细节:使用LLONG_MIN/LLONG_MAX(需包含<climits>头文件)而非普通 int 极值,防止节点值为 int 最大值 / 最小值时的溢出问题;
  3. 效率特点:每个节点仅被校验一次,时间O(n);递归栈空间取决于树的高度,平衡树为O(log n),退化为链表时为O(n)

函数源码:

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: bool f(TreeNode* node,long long l,long long r){ if(!node) return true; int dx=node->val; if(l>=dx||dx>=r) return false; return f(node->left,l,dx) && f(node->right,dx,r); } bool isValidBST(TreeNode* root) { return f(root,LLONG_MIN,LLONG_MAX); } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/2 17:43:11

微信小程序毕设项目推荐-基于springboot的保护濒危动物公益网站系统公益网站建设、动物保护系统、濒危物种网站【附源码+文档,调试定制服务】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/11 8:57:47

得物Java面试被问:Netty的ByteBuf引用计数和内存释放

一、ByteBuf 内存模型 1. ByteBuf 结构概览 java 复制 下载 /*** ByteBuf 内存层次结构*/ public class ByteBufMemoryModel {/*** ByteBuf 的两种主要类型&#xff1a;* 1. Heap Buffer&#xff08;堆缓冲区&#xff09;* - 存储在 JVM 堆内存* - 快速分配和释放* …

作者头像 李华
网站建设 2026/4/16 12:21:18

计算机小程序毕设实战-基于springboot的保护濒危动物公益网站系统科普展示、公益行动、捐赠管理【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/16 12:49:11

全网最全专科生AI论文网站TOP9:毕业论文写作测评

全网最全专科生AI论文网站TOP9&#xff1a;毕业论文写作测评 2026年专科生AI论文写作工具测评&#xff1a;为何需要这份榜单&#xff1f; 随着人工智能技术的不断发展&#xff0c;越来越多的专科生开始借助AI工具辅助毕业论文的撰写。然而&#xff0c;面对市场上琳琅满目的平台…

作者头像 李华
网站建设 2026/4/16 12:54:56

无线网络仿真:蓝牙网络仿真_(4).蓝牙网络仿真工具介绍

蓝牙网络仿真工具介绍 在上一节中&#xff0c;我们已经了解了蓝牙网络的基本概念和工作原理。本节将详细介绍几种常用的蓝牙网络仿真工具&#xff0c;包括它们的特性和应用场景&#xff0c;以及如何使用这些工具进行蓝牙网络的仿真和分析。 1. NS-3 (Network Simulator 3) 1.1 …

作者头像 李华
网站建设 2026/4/16 12:42:08

开发智力的课堂

假期充电模式&#xff0c;小朋友认真上课的样子&#xff0c;别人的假期在玩耍&#xff0c;娃们的假期在赶课&#xff0c;努力的小孩最可爱&#xff0c; 假期不虚度&#xff0c;成长不止步&#xff0c;课堂上的小身影&#xff0c;正在悄悄积攒能量&#xff0c;收获满满[太阳][跳…

作者头像 李华