1月18日代码随想录二叉树搜索、验证二叉搜索树

700.二叉搜索树中的搜索

给定二叉搜索树(BST)的根节点 root 和一个整数值 val

你需要在 BST 中找到节点值等于 val 的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 null 。

示例 1:

输入:root = [4,2,7,1,3], val = 2
输出:[2,1,3]

示例 2:

输入:root = [4,2,7,1,3], val = 5
输出:[]

提示:

  • 树中节点数在 [1, 5000] 范围内
  • 1 <= Node.val <= 107
  • root 是二叉搜索树
  • 1 <= val <= 107

思路

迭代法秒了,递归都不想看

class Solution {public TreeNode searchBST(TreeNode root, int val) {while(root!=null){if (root.val == val) {return root;} else if (root.val > val) {root=root.left;}else {root=root.right;}}return null;}
}

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

思路

刚开始的想法是定义两个递归函数互相调用,一个判断左子树一个判断右子树,每次递归时把上一个节点的值记录下来传给下一个。

class Solution {public boolean isValidBST(TreeNode root) {if (root == null) {return false;}return isValidLeft(root.left,root.val)&&isValidRight(root.right,root.val);}public boolean isValidLeft(TreeNode node,int val){if (node == null) {return true;}if (node.val >= val) {return false;}return isValidLeft(node.left,node.val)&&isValidRight(node.right,node.val);}public boolean isValidRight(TreeNode node,int val){if (node == null) {return true;}if (node.val <= val) {return false;}return isValidLeft(node.left,node.val)&&isValidRight(node.right,node.val);}
} 

但这就犯了一个很严重的错误,就是只考虑每个节点的父节点的范围,没有考虑当前节点所在的整个子树,所以我们应该设置一个全局的值来判断是否为二叉搜索树。

class Solution {public boolean isValidBST(TreeNode root) {if(root==null){return false;}return isValid(root,Long.MIN_VALUE,Long.MAX_VALUE);}public boolean isValid(TreeNode node,long min,long max){if(node==null){return true;}if (node.val <= min || node.val >= max) {return false;}return isValid(node.left,min,node.val)&&isValid(node.right,node.val,max);}}

迭代法:二叉搜索树的中序遍历一定是有序的,所以对二叉树进行中序遍历即可。

class Solution {public boolean isValidBST(TreeNode root) {Deque<TreeNode> stack=new LinkedList<TreeNode>();double inorder=-Double.MAX_VALUE;while(!stack.isEmpty()||root!=null){while (root != null) {stack.push(root);root=root.left;}root=stack.pop();if (root.val <= inorder) {return false;}inorder=root.val;root=root.right;}return true;}
}

总结

递归法一定要注意全局的条件,不能只继承上一次递归的。

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

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

相关文章

Dotnet Cli 创建解决方案sln 以及添加项目到解决方案

创建解决方案 dotnet new sln -n name添加项目到解决方案 dotnet sln add xxx.csproj解决方案中的项目列表 dotnet sln list https://www.cnblogs.com/microestc/articles/13796631.html

医院网络安全建设:三网整体设计和云数据中心架构设计

医院网络安全问题涉及到医院日常管理多个方面&#xff0c;一旦医院信息管理系统在正常运行过程中受到外部恶意攻击&#xff0c;或者出现意外中断等情况&#xff0c;都会造成海量医疗数据信息的丢失。由于医院信息管理系统中存储了大量患者个人信息和治疗方案信息等&#xff0c;…

Django的数据库操作中的F对象是什么东西?

在Django中&#xff0c;F对象是一个用于表示数据库字段的值的特殊对象。 它允许你在数据库层面进行原子操作&#xff0c;而不需要先将数据从数据库中检索到Python层再进行操作。 F对象的使用通常涉及到数据库更新&#xff0c;特别是在处理并发操作时。 以下是F对象的主要特性和…

[面试题~]Golang

3. 数组和切片 3.1 数组和切片的区别 Go语言中数组是固定长度的&#xff0c;不能动态扩容&#xff0c;在编译期就会确定大小。 切片是一种数据结构&#xff0c;包含一个底层数组的指针&#xff0c;当前切片个数 len 以及切片的最大容量 cap&#xff0c; 描述的是一块数组。 …

FineBI实战项目一(25):实战项目一总结

实在项目使用mysql做数仓库的ODS层&#xff0c;这仅仅是带领大家入门&#xff0c;用mysql做数仓存在很多问题。以实战项目一为例&#xff1a; 1 存在的问题 目前调度用的kettle&#xff0c;数据分析&#xff0c;计算都是落表到mysqlmysql表数量庞大&#xff0c;乱&#xff0c…

css基本写法--详解大全

目录 1.行内样式 2.内嵌样式 3.外链样式 4.import 5.注意 加载顺序 1.行内样式 我们要某个 HTML 标签中去书写样式&#xff0c;它需要使用 style 属性来指定。 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"&g…

【ArcGIS微课1000例】0088:计算城市建筑物朝向(矩形角度)

文章目录 一、实验描述二、实验数据三、角度计算1. 添加字段2. 计算角度四、方向计算一、实验描述 矩形要素具有长轴和短轴,其长轴方向也称为矩形面的主角度,可用于确定面要素的走向趋势。根据该方向参数,可以对具有矩形特征的地理对象进行方向分析,且适用于很多应用场景,…

什么是NodeJS

1、前言 接触 node.js 有好几年了&#xff0c;也开发了好几个项目了&#xff1b;但每次提起 node.js&#xff0c;始终不敢说自己入门了&#xff0c;归其原因&#xff0c;大概就是如下所示 为了进一步加强理解&#xff0c;系统的梳理相关知识以作备忘&#xff0c;本节将从以下…

视频转码实例:把MP4转为MKV视频,一键批量转换的操作方法

在数字媒体时代&#xff0c;视频格式的多样性是不可避免的。经常把MP4格式的视频转换为MKV格式。MKV格式有较高的音频和视频质量&#xff0c;能在其他设备或软件上播放视频。以下是云炫AI智剪如何把MP4视频转为MKV格式的一键批量转换操作方法。 已转码的mkv视频效果缩略图展示…

20240117在本地机器识别OCR法语电影的字幕效果PK

20240117在本地机器识别OCR法语电影的字幕效果PK 2024/1/17 11:18 1959 - Jirai Cracher Sur Vos Tombes [Gast, Vian].avi https://www.pianbar.net//drama/52892.html 1959[我唾弃你的坟墓]Jirai cracher sur vos tombes[BT下载/迅雷下载] magnet:?xturn:btih:7c9c99d9d048…

Elasticsearch各种高级文档操作

本文来记录下Elasticsearch各种文档操作 文章目录 初始化文档数据查询所有文档匹配查询文档关键字精确查询文档多关键字精确查询文档字段匹配查询文档指定查询字段查询文档过滤字段查询文档概述指定想要显示的字段示例指定不想要显示的字段示例 组合查询文档范围查询文档概述使…

智慧营业厅AI智能视频监控预警系统-商超类连锁店监控解决方案---豌豆云

针对银行、政务、保险、通信、汽车、高速等实体营业厅和办事大厅&#xff0c;提供算力算法平台一体化的智慧营业厅解决方案。 基于边缘端强大的算力&#xff0c;搭配根据行业需求定制化的AI视频分析算法&#xff0c;帮助实现营业厅提升数字化管理水平&#xff0c;加强个性化服…

微服务入门 | 项目分割 | 远程调度Feign | 用户中心erueka 和 nacos

认识微服务 微服务架构演变&#xff1a; 单体架构&#xff1a;所有功能集中在一个项目中开发&#xff0c;打成一个包部署 分布式架构&#xff1a;就是各功能模块的代码不在同一个项目中写了&#xff0c;到时候修改其中一个过能的代码&#xff0c;对另一个功能完全没有任何影响…

循环异步调取接口使用数组promiseList保存,Promise.all(promiseList)获取不到数组内容,then()返回空数组

在使用 vue vant2.13.2 技术栈的项目中&#xff0c;因为上传文件的接口是单文件上传&#xff0c;当使用批量上传时&#xff0c;只能循环调取接口&#xff1b;然后有校验内容&#xff1a;需要所有文件上传成功后才能保存&#xff0c;在文件上传不成功时点击保存按钮&#xff0c…

非常有趣的AI应用-用大语言模型来玩星际争霸2(附代码链接)

非常有趣的AI应用-用大语言模型来玩星际争霸2&#xff08;附代码链接&#xff09; 偶然看到的&#xff0c;比较有意思&#xff0c;分享一下&#xff1a; GitHub地址&#xff1a;Large-Language-Models-play-StarCraftII arxiv&#xff1a;Large Language Models Play StarCra…

ChatGPT 报:“Unable to load history…”如何处理?

ChatGPT界面出现&#xff1a;“Unable to load history…” 说明&#xff1a;无法加载历史记录。。。 原因&#xff1a; 一般是代理的问题&#xff0c;网络加载延迟严重&#xff0c;也可能是官方请求过多&#xff0c;造成响应不及时。 解决&#xff1a; 出现这个问题时&#…

新三板操作指南!哪家证券公司开通新三板交易佣金费率最低?

新三板操作指南&#xff1a;掌握规则&#xff0c;赢得先机&#xff01; 随着中国资本市场的蓬勃发展&#xff0c;新三板市场日益成为投资者关注的焦点。然而&#xff0c;对于许多新手投资者来说&#xff0c;新三板市场的交易规则和流程可能较为陌生。本文将为您详细解读新三板…

移动端开发进阶之蓝牙通讯(一)

移动端开发进阶之蓝牙通讯&#xff08;一&#xff09; 移动端进阶之蓝牙通讯需要综合考虑蓝牙版本选择、协议栈使用、服务匹配、设备连接、安全性和硬件支持等方面。 一、蓝牙版本选择 根据实际需求和应用场景选择合适的蓝牙版本&#xff1b; 1.0&#xff0c;1M/s。 2.0EDR…

线程安全的集合类

Java中提供了许多集合类&#xff0c;其中有的是线程安全的&#xff0c;有的是线程不安全的。线程安全的集合类有&#xff1a; 1. Vector&#xff1a;Vector类实现了一个动态数组&#xff0c;与ArrayList相似&#xff0c;但Vector是同步访问的 2. Stack&#xff1a;Stack是Vec…

C++ 数论相关题目(约数)

1、试除法求约数 主要还是可以成对的求约数进行优化&#xff0c;不然会超时。 时间复杂度根号n #include <iostream> #include <vector> #include <algorithm>using namespace std;int n;vector<int> solve(int a) {vector<int> res;for(int i…