二叉搜索树,力扣

目录

题目地址:

题目:

我们直接看题解吧:

解题分析:

解题思路:

代码实现:

代码补充说明:

代码实现(中序遍历):


题目地址:

98. 验证二叉搜索树 - 力扣(LeetCode)
难度:中等

今天刷验证二叉搜索树,大家有兴趣可以点上面链接,看看题目要求,试着做一下。

题目:

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

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

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

我们直接看题解吧:

快速理解解题思路小建议:

可以先简单看一下解题思路,然后照着代码看思路,会更容易理解一些。

解题方法:

方法1,递归

方法2,中序遍历

中序遍历相关题目及解题:

二叉树的中序遍历,力扣-CSDN博客

解题分析:

由题意可知二叉搜索树的定义:

· 如果该二叉树的左子树不为空,则左子树上所有节点的值均小于它的根节点的值;

· 若该二叉树的右子树不空,则右子树上所有节点的值均大于它的根节点的值;

·它的左右子树也为二叉搜索树。

解题思路:

1、核心思路:

设计递归函数以root为根的子树,判断子树中所有的节点的值是否在(l,r)区间范围内(开区间)

若满足范围要求则继续调用它的左右子树是否满足(若都满足则为二叉树),

若不满足则直接返回false

2、具体递归调用:

递归调用左子树,需将上界upper改为root.val,即左子树的所有节点的值均小于它的根节点的值;

递归递归调用右子树,则需要将下界lower改为root.val,即右子树的所有节点的值均大于它的根节点的值;
可结合力扣解题思路-->98. 验证二叉搜索树 - 力扣(LeetCode)

代码实现:

复制代码
class Solution {
    public boolean isValidBST(TreeNode root) {
        return isValidBST(root, Long.MIN_VALUE, Long.MAX_VALUE);//函数递归入口
    }

    public boolean isValidBST(TreeNode node, long lower, long upper) {
        if (node == null) {  //判断节点是否null,即是否为叶子节点
            return true;
        }
        if (node.val <= lower || node.val >= upper) {
            return false;//判断范围,若不在区间范围内则返回false结束递归
        }
        return isValidBST(node.left, lower, node.val) 
           && isValidBST(node.right, node.val, upper);
          //若在区间范围内,则递归调用该节点的左右子树
    }
}
代码补充说明:

1、函数递归调用的入口为helper(root,-inf,+inf),-inf表示long类型的最小值,+inf反之

注意第一次调用时上下界 是不可用的,需调用其左右子树,

-inf,+inf作用是确保不出现数据范围越界

2、为防止出现数据边界越界的问题,由于整个树的数据类型都是Int,用Int的话值会被覆盖掉,而long类型覆盖了整个Int类型的范围,因此将数据类型设置为long

代码实现(中序遍历):

由中序遍历的访问特点"左节点 -> 根节点 -> 右节点",

再根据二叉搜索树的特点"左节点的值 < 当前结点的值 < 右节点的值",

我们可以利用这两个特性得出:

我们在中序遍历的时候实时检查当前结点的值是否大于前一个中序遍历到的结点的值即可。

因为按照"左 -> 根 -> 右"的顺序遍历,刚好结点间的值是从小到大排序的。

所以,如果均大于则说明这个序列是升序的,整棵树是二叉搜索树,否则不是。

复制代码
class Solution {
 
     long pre = Long.MIN_VALUE;//创建临时变量,存储前一节点的值,初始为long的最小值
    public boolean isValidBST(TreeNode root) {
        if (root == null) {
            return true;
        }
         // 访问左子树,如果左子树中任意一个节点出错就可以直接返回false,不用后续再遍历了
        if (!isValidBST(root.left)) {
            return false;
        }
        // 访问当前节点:若当前节点小于等于中序遍历的前一个节点,说明不满足BST,返回 false;
        if (root.val <= pre) {
            return false;
        }
        // 若当前节点大于中序遍历的前一个节点,则更新变量pre的值;
        pre = root.val;
        // 接着访问右子树
        return isValidBST(root.right);
    }
}
相关推荐
秋难降25 分钟前
栈:从基础概念到实战解题(详细)
数据结构·算法·排序算法
归云鹤27 分钟前
QT信号和槽怎么传输自己定义的数据结构
开发语言·数据结构·qt
ezl1fe40 分钟前
RAG 每日一技(十):向量检索的“死穴”?用混合搜索(Hybrid Search)来拯救!
后端·算法
Ahu_iii43 分钟前
【图论基础】理解图的“闭环”:Tarjan 强连通分量算法全解析
算法·图论
PixelMind1 小时前
【IQA技术专题】DISTS代码讲解
图像处理·人工智能·python·算法·iqa
项目申报小狂人1 小时前
2025年1中科院1区顶刊SCI-投影迭代优化算法Projection Iterative Methods-附完整Matlab免费代码
开发语言·算法·matlab
AI 嗯啦1 小时前
机械学习--逻辑回归
算法·机器学习·逻辑回归
山烛1 小时前
逻辑回归详解:从数学原理到实际应用
python·算法·机器学习·逻辑回归
爱煲汤的夏二2 小时前
扩展卡尔曼滤波器 (EKF) 与无人机三维姿态估计:从理论到实践
单片机·嵌入式硬件·算法·无人机
sali-tec2 小时前
C# 基于halcon的视觉工作流-章27-带色中线
开发语言·人工智能·算法·计算机视觉·c#