二叉搜索树,力扣

目录

题目地址:

题目:

我们直接看题解吧:

解题分析:

解题思路:

代码实现:

代码补充说明:

代码实现(中序遍历):


题目地址:

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);
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/365422.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Web3智能合约:重新定义商业合作的未来

随着区块链技术的飞速发展&#xff0c;Web3时代正逐渐到来&#xff0c;而其中的智能合约成为推动商业合作变革的关键力量。本文将深入探讨Web3智能合约的概念、特点以及对商业合作未来的巨大影响。 什么是Web3智能合约&#xff1f; 智能合约是一种以代码形式编写、自动执行合同…

智能末世战争之机器人的反击

在遥远的未来&#xff0c;地球陷入了一场空前的战争。这场战争不同于以往的任何战争&#xff0c;因为这是由人工智能和机器人主导的战争。在战争爆发之前&#xff0c;人类一直依赖AI和机器人来提高生产效率和生活质量。然而&#xff0c;随着AI技术的飞速发展&#xff0c;机器人…

Open CASCADE学习|曲面上一点的曲率及切平面

曲率&#xff08;Curvature&#xff09;是一个几何学的概念&#xff0c;用于描述一个物体的形状在某一点上的弯曲程度。在我们日常生活中&#xff0c;曲率与我们的生活息息相关&#xff0c;如道路的弯道、建筑物的拱形结构、自然界的山脉等等。了解曲率的概念和计算方法&#x…

GM8775C——DSI 转双通道 LVDS 发送器

1 产品概述 GM8775C 型 DSI 转双通道 LVDS 发送器产品主要实现将 MIPI DSI 转单 / 双通道 LVDS 功能&#xff0c; MIPI 支持 1/2/3/4 通道可选&#xff0c;每通道最高支持 1Gbps 速率&#xff0c;最大支持 4Gbps 速率。 LVDS 时钟频率高达 154MHz &#xff…

C/C++ C++入门

个人主页&#xff1a;仍有未知等待探索-CSDN博客 专题分栏&#xff1a;C_仍有未知等待探索的博客-CSDN博客 目录 一、C关键字 二、命名空间 1、区别 1. C语言 ​编辑 2. C 2、命名空间定义 3、命名空间的使用 三、C输入&输出 四、缺省参数 五、函数重载 六、引用 …

三步实现 Sentinel-Nacos 持久化

一、背景 版本&#xff1a;【Sentinel-1.8.6】 模式&#xff1a;【Push 模式】 参照官网介绍&#xff1a;生产环境下使用Sentinel &#xff0c;规则管理及推送模式有以下3种模式&#xff1a; 比较之后&#xff0c;目前微服务都使用了各种各样的配置中心&#xff0c;故采用Pus…

UE5 虚幻游戏报错常用解决方法(幻兽帕鲁UE5报错)

在体验使用虚幻引擎5、4&#xff08;UE5/UE4&#xff09;开发的游戏如《幻兽帕鲁》时&#xff0c;玩家可能会遇到各种报错情况&#xff0c;例如黑屏、闪退、C运行时错误等。本博客将汇集一系列有效解决方案&#xff0c;通过调整虚幻引擎内置命令行参数以及优化系统环境&#xf…

mysql 批量查询取每一组最新一条数据

AI回答 需求 根据车牌号查询最新的一条交车记录的‘合同号’ &#xff0c;与上面需要类似&#xff0c;这里只需要查询‘合同号’这个字段 方式1 直接把需要查询的字段加上contract_no&#xff0c;直接查&#xff0c;不用子查询 SELECT number_plate,id,contract_no, MAX( …

K8S-NFS-StorageClass

工作流程 K8s中部署NFS-StorageClass K8s的StorageClass提供了为集群动态创建PV的能力。 1.部署NFS服务 2.选择NFS的Provinisoner驱动 K8S中没有内置的NFS的制备器&#xff0c;而定义StorageClass的时候需要指定制备器&#xff08;Pervisioner&#xff09;,所以需要&#xf…

EtherCAT转ModbusTCP网关

一、功能概述 1.1设备简介 本产品是EtherCAT和Modbus TCP网关&#xff0c;使用数据映射方式工作。 本产品在EtherCAT侧作为EtherCAT从站&#xff0c;接TwinCAT、CodeSYS、PLC等&#xff1b;在ModbusTCP侧做为ModbusTCP主站&#xff08;Client&#xff09;或从站&#xff08;…

Windows - 防火墙 - 如何开启单个端口以供Web应用访问(以82端口为例) - 开启端口后还是访问失败了?

Windows - 防火墙 - 如何开启单个端口以供Web应用访问(以82端口为例) - 开启端口后还是访问失败了&#xff1f; 前言 在网上搜“防火墙开启某个端口”供其他机器访问&#xff0c;都是只讲到了“如何允许某个端口被访问”&#xff0c;而没有后续了。 我之前就遇到过这个问题&…

寒假用它练脑子!和AI大战几百回合,锻炼思维逻辑、专注力~

棋类游戏&#xff0c;永远是锻炼思维能力的优选。 下棋对于孩子的成长有诸多好处&#xff0c;比如会让孩子静下心来&#xff0c;锻炼洞察力和专注力。生死对决与全盘的计算&#xff0c;促使思维力扩展。棋盘上的设计和构筑&#xff0c;丰富孩子的想象力等等。 下棋过程中大量的…

docker集成 nacos/nacos-server (包括踩的坑)

tips 这边需要的数据库我已经安装好了&#xff0c;所以数据库的安装这边已经省略了 拉取镜像&#xff08;这边使用nacos1.4.1作为例子&#xff09; docker pull nacos/nacos-server:1.4.1创建映射的文件夹 (conf存放配置文件&#xff0c;logs存放日志文件) mkdir -p /data/n…

【EI会议征稿通知】2024年生成式人工智能与信息安全国际学术会议(GAIIS 2024)

2024年生成式人工智能与信息安全国际学术会议&#xff08;GAIIS 2024&#xff09; 2024 International Conference on Generative Artificial Intelligence and Information Security 2024年生成式人工智能与信息安全国际学术会议&#xff08;GAIIS 2024&#xff09;将于 202…

【机器学习】基于K-近邻的车牌号识别

实验四: 基于K-近邻的车牌号识别 1 案例简介 ​ 图像的智能处理一直是人工智能领域广受关注的一类技术&#xff0c;代表性的如人脸识别与 CT 肿瘤识别&#xff0c;在人工智能落地的进程中发挥着重要作用。其中车牌号识别作为一个早期应用场景&#xff0c;已经融入日常生活中&…

【Web前端笔记06】CSS常用属性

目录 一、字体属性 1、color 字体颜色 2、font-size 字体大小&#xff08;默认16px) 3、font-weight 文本粗细 4、font-style 字体样式 5、font-family 指定一个元素的字体 二、背景属性 1、background-color 背景颜色 2、background-image: url("img/do.png"); 背景…

Linux-485接口

接口引脚定义 2线485通信方法 在 2 线制 RS-485 中&#xff0c;设备之间共享一条数据线&#xff08;D 和 D-&#xff09;&#xff0c;因此需要一种机制来区分哪个设备正在发送数据&#xff0c;哪个设备处于接收状态。 对于这种情况&#xff0c;常用的方法是在总线上使用一个控…

双目视觉目标追踪及三维坐标获取—python(代码)

2022年九月更新&#xff1a; 在原来的基础上&#xff0c;我使用了yolov5代替了opencv的目标检测算法辅助相机进行三维坐标的获取&#xff0c;并成功用获取的坐标实时控制机械臂&#xff0c;感兴趣的话可以看我b站里的视频&#xff0c;视频下方也有开源的链接&#xff1a;【软核…

【教程】Objective-C 性能监控

1、内存监控 CPU内存监控 克魔助手提供了分析内存占用、查看 CPU 实时活动数据以及追踪特定应用程序的功能&#xff0c;让开发者可以更好地了解应用程序的运行情况。 以下是一些示例截图&#xff1a; 同样&#xff0c;克魔助手还提供了内存、GPU 性能监控、网络监控等功能&am…

什么是接口的幂等性,如何保证接口的幂等性?

✅作者简介&#xff1a;大家好&#xff0c;我是Leo哥&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo哥的博客 &#x1f49e;当前专栏&#xff1a; Java ✨特色专栏&#xff1a; MyS…