二叉搜索树,力扣

news2024/11/19 13:32:31

目录

题目地址:

题目:

我们直接看题解吧:

解题分析:

解题思路:

代码实现:

代码补充说明:

代码实现(中序遍历):


题目地址:

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.coloradmin.cn/o/1428257.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CSS 星空按钮

<template><button class="btn" type="button"><strong>星空按钮</strong><div id="container-stars"><div id="stars"></div></div><div id="glow"><div class=…

怎么控制Element的数据树形表格展开所有行;递归操作,打造万能数据表格折叠。

HTML <el-button type"success" size"small" click"expandStatusFun"> <span v-show"expandStatusfalse"><i class"el-icon-folder-opened"></i>展开全部</span><span v-show"expan…

解决nvm切换node版本后原先npm全局安装(npm i -g)的包无法使用

找到node14版本下的node_global文件夹&#xff0c;复制文件夹路径&#xff0c;然后点击环境变量、系统编辑&#xff0c;点击path、点击编辑 在终端输入npm config set prefix “E:\devSoft\git\nvm\v14.18.3\node_global”&#xff0c;其中E:\devSoft\git\nvm\v14.18.3\node_g…

【软件工程】建模工具之开发各阶段绘图——UML2.0常用图实践技巧(功能用例图、静态类图、动态序列图状态图活动图)

更多示例图片可以参考&#xff1a;&#xff08;除了常见的流程图&#xff0c;其他都有&#xff09; 概念&#xff1a;类图 静态&#xff1a;用例图 动态&#xff1a;顺序图&状态图&活动图 1、【面向对象】UML类图、用例图、顺序图、活动图、状态图、通信图、构件图、部…

2024年美赛 (D题ICM)| 湖流网络水位控制 |数学建模完整代码+建模过程全解全析

当大家面临着复杂的数学建模问题时&#xff0c;你是否曾经感到茫然无措&#xff1f;作为2022年美国大学生数学建模比赛的O奖得主&#xff0c;我为大家提供了一套优秀的解题思路&#xff0c;让你轻松应对各种难题。 让我们来看看美赛的D题&#xff01; 完整内容可以在文章末尾领…

网络原理-TCP/IP(4)

TCP原理 滑动窗口 之前我们讲过了确认应答策略,对发送的每一个数据段,都要给一个ACK确认应答,收到ACK后再发送下一个数据段. 确认应答,超时重传,连接管理这样的特性都是为了保证可靠运输,但就是付出了传输效率(单位时间能传输数据的多少)的代价,因为确认应答机制导致了时间大…

hivesql的基础知识点

目录 一、各数据类型的基础知识点 1.1 数值类型 整数 小数 float double(常用) decimal(针对高精度) 1.2 日期类型 date datetime timestamp time year 1.3 字符串类型 char varchar / varchar2 blob /text tinyblob / tinytext mediumblob / mediumtext lon…

字符串的简单处理

第1题 ISBN号码 查看测评数据信息 每一本正式出版的图书都有一个ISBN号码与之对应&#xff0c;ISBN码包括9位数字、1位识别码和3位分隔符&#xff0c;其规定格式如“x-xxx-xxxxx-x”&#xff0c;其中符号“-”就是分隔符&#xff08;键盘上的减号&#xff09;&#xff0c;最…

图像超分辨率方法与在线工具

图像超分辨率(Super Resolution, SR)是一种增强图像分辨率的技术&#xff0c;目的是从低分辨率(Low Resolution, LR)图像重建出高分辨率(High Resolution, HR)图像。这项技术在视频增强、卫星图像处理、医学成像等领域有广泛应用。图像超分辨率方法可以分为三大类&#xff1a;插…

Python算法题集_矩阵置零

Python算法题集_矩阵置零 题73&#xff1a;矩阵置零1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【三层循环】2) 改进版一【纵横计数器】3) 改进版二【原地算法】 4. 最优算法 本文为Python算法题集之一的代码示例 题73&#xff1a;矩阵置零…

linux ln命令-linux软链接、硬链接-linux软、硬链接的区别(二):软链接

0、序 上一篇&#xff1a;linux ln命令-linux软链接、硬链接-linux软、硬链接的区别(一)&#xff1a;硬链接 描述了硬链接相关内容&#xff0c;本篇主要描述软链接。 1、软链接 符号链接也称软链接&#xff0c;是将一个路径名链接到一个文件。这些文件是一种特别类型的文件。…

【JS】Express.js环境配置与示例

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍Express.js环境配置与示例。 学其所用&#xff0c;用其所学。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下次更新不…

【云手机】快速获取一台属于你的云手机,在云上调试你的应用!

0x00 前言 随着科技的飞速发展&#xff0c;云手机已然成为一种云端虚拟商品&#xff0c;它打破地域限制&#xff0c;让你随时随地畅享移动体验。红手指、小鱼云手机等平台虽便捷易用&#xff0c;却在可扩展性和隐私性方面有所欠缺。冗长的《隐私政策》是否让你望而却步&#x…

C++通用编程(2)

函数模板高级用法 1.分文件编写的优点2.普通函数的分文件编写3.函数模板的分文件编写4.细节提示5.函数模板应用高级decltype推导类型函数后置返回类型 6.总结 函数模板讲完后&#xff0c;C全部的函数类型我们就接触的差不多了。今天给做一些关于函数份文件编写的知识点补充。 1…

C# winform 多语言(json)方式实现

前后对比 使用nuget json工具包1.总体思路 创建对应的json字典对照表 { "测试":"Test", "语言":"Language", "设置":"Set", "中文(默认)":"Chinese (default)", "英文":"E…

【对象属性拷贝】⭐️按照需要转换的类型反射设置拷贝后对象的属性

背景&#xff1a; 小伙伴们大家好&#xff0c;最近开发的时候遇到一种情况&#xff0c;项目引入了全局序列化器来实现Date&#xff0c;LocalDateTime类型的字段根据时区转换&#xff0c;总体来说接口没什么要改动的&#xff0c;只要原来字段的属性是以上两种就行&#xff0c;但…

【linux】校招中的“熟悉linux操作系统”一般是指达到什么程度?

这样&#xff0c;你先在网上找一套完整openssh升级方案&#xff08;不是yum或apt的&#xff0c;要源码安装的&#xff09;&#xff0c;然后在虚拟机上反复安装测试&#xff0c;直到把他理解了、背下来。 面试的时候让你简单说说linux命令什么的&#xff0c;你就直接把这个方案…

Linux服务详解

如有错误或有补充&#xff0c;以及任何改进的意见&#xff0c;请在评论区留下您的高见&#xff0c;同时文中给出大部分命令的示例&#xff0c;即是您暂时无法在Linux中查看&#xff0c;您也可以知道各种操作的功能以及输出 如果觉得本文写的不错&#xff0c;不妨点个赞&#x…

CentOS 7中搭建NFS文件共享服务器的完整步骤

CentOS 7中搭建NFS文件共享服务器的完整步骤 要求&#xff1a;实现镜像文件共享&#xff0c;并基于挂载的共享目录配置yum源。 系统环境&#xff1a; 服务器&#xff1a;172.20.26.167-CentOS7.6 客户端&#xff1a;172.20.26.198-CentOS7.6 1、在服务器和客户端上&#x…

案例分析技巧-软件工程

一、考试情况 需求分析&#xff08;※※※※&#xff09;面向对象设计&#xff08;※※&#xff09; 二、结构化需求分析 数据流图 数据流图的平衡原则 数据流图的答题技巧 利用数据平衡原则&#xff0c;比如顶层图的输入输出应与0层图一致补充实体 人物角色&#xff1a;客户、…