验证二叉搜索树-递归双指针法

news/2024/11/29 20:37:20/

1题目

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

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

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

示例 1:

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

示例 2:

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

2链接

题目链接:98. 验证二叉搜索树 - 力扣(LeetCode)

视频链接:你对二叉搜索树了解的还不够! | LeetCode:98.验证二叉搜索树_哔哩哔哩_bilibili

3解题思路

这道题目比较容易陷入两个陷阱:

  • 陷阱1

不能单纯的比较左节点小于中间节点,右节点大于中间节点就完事了

我们要比较的是 左子树所有节点小于中间节点,右子树所有节点大于中间节点。所以以上代码的判断逻辑是错误的。

例如: [10,5,15,null,null,6,20] 这个case:

节点10大于左节点5,小于右节点15,但右子树里出现了一个6 这就不符合了!

 

  • 陷阱2

样例中最小节点 可能是int的最小值,如果这样使用最小的int来比较也是不行的。

此时可以初始化比较元素为longlong的最小值。当然也可以避开设置最小值来比较,例如采用双指针法一样可以得到结果

4代码

class Solution {
public:TreeNode* pre = nullptr; //用来记录前一个节点bool isValidBST(TreeNode* root) {if (root == nullptr) return true;bool left = isValidBST(root->left);if (pre != nullptr && pre->val >= root->val) {return false;}pre = root; //记录前一个节点bool right = isValidBST(root->right);return left && right;}
};


http://www.ppmy.cn/news/58435.html

相关文章

96. 不同的二叉搜索树

目录 1、题目描述 2、思路:动态规划 2.2、确定递推公式 2.3、dp数组初始化 2.4、确定遍历顺序 3、C实现如下 1、题目描述 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜…

Mybatis读取和存储json类型的数据

目录 一、测试使用JSONObject来获取json二、设置TableName的autoResultMap为true,TableField的typeHandler为JacksonTypeHandler.class三、设置xml当中的resultMap四、JacksonTypeHandler讲解五、新增假如是JSONObject异常问题六、遇到转义的问题 不管数据库当中是以…

ospf扩展配置—认证、沉默接口、加快收敛、缺省路由

目录标题 认证接口认证区域认证虚链路认证 沉默接口加快收敛缺省路由3类缺省5类缺省7类缺省 总结 认证 在直连的邻居或邻接之间,配置身份核实秘钥来保障邻居、邻接间数据沟通的安全性 接口认证 在这连连接的接口上配置 [r6-GigabitEthernet0/0/1]ospf authentic…

生成C++工程的UML类图和类继承关系图

简介 在进行软件开发时,了解代码结构和关系、类之间的继承关系以及类内部的成员函数和变量定义是非常重要的。为此,我们可以使用Doxygen和Graphviz工具来生成UML类图和类集成关系图。 Doxygen是一个用于从注释的C源代码中生成文档的工具,支…

Ubuntu---mysql出现ERROR1698(28000):Access denied for user root@localhost错误解决方法

查看mysql版本: 安装完成后,登录mysql的时候就出现了如下错误: 因为安装的过程中没让设置密码,可能密码为空,但无论如何都进不去mysql。 下面是处理过程: Step1:修改mysqld.cnf配置文件 在ubun…

(九)Geoprocessing地理处理框架——ArcToolbox内容简介

(九)Geoprocessing地理处理框架——ArcToolbox内容简介 目录 (九)Geoprocessing地理处理框架——ArcToolbox内容简介 1.工具集简介1.1 3D Analyst工具箱:1.2分析工具箱:1.3制图工具箱:1.4转换工具箱:1.5Data Interoper…

PACS系统源码,大型医院PACS源码集成三维重建

PACS系统为医院提供包括放射、超声、核医学、病理、内窥镜、心电图室在内的所有影像检查数字化的一体化解决方案。 它涵盖了传统PACS和RIS系统的所有功能,以构建全数字化影像科为目标,致力于实现对医院所有影像数据的统一管理、影像检查工作流的自动化&a…

项目连载方式

协议介绍 芯片介绍 读写操作 小熊派驱动系列连载正点原子的代码重新用Cubemx实现协议分析项目制作单片机上云的代码移植可以使用Arduino接管或者使用以太网、或者ESP8266移植开源项目复刻 在小熊派的板子上进行简单的步骤实现,函数分析,在正点原子的…