剑指offer:(23)举例让抽象问题具体化 :二叉搜索树的后序遍历序列

本文主要是介绍剑指offer:(23)举例让抽象问题具体化 :二叉搜索树的后序遍历序列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。

二叉树搜索树就是二叉排序树,所有节点的左子树都小于它,右子树都大于它

解法:递归法

          非递归法

package co.com.jianzhioffer;public class Solution24 {/** 非递归  非递归也是一个基于递归的思想: 左子树一定比右子树小,因此去掉根后,数字分为left,right两部分,right部分的* 最后一个数字是右子树的根他也比左子树所有值大,因此我们可以每次只看有子树是否符合条件* 即可,即使到达了左子树左子树也可以看出由左右子树组成的树还想右子树那样处理* 对于左子树回到了原问题,对于右子树,左子树的所有值都比右子树的根小可以暂时把他看出右子树的左子树 只需看看右子树的右子树是否符合要求即可*//** public boolean VerifySquenceOfBST(int[] sequence) { int size =* sequence.length; if(size==0) return false;* * int i = 0; while(--size!=0){ while(sequence[i++]<sequence[size]);* while(sequence[i++]>sequence[size]);* * if(i<size) return false; i=0; } return true; }*//** 递归方式* BST的后序序列的合法序列是,对于一个序列S,最后一个元素是x (也就是根),* 如果去掉最后一个元素的序列为T,那么T满足:T可以分成两段,前一段(左子树)小于x,后一段(右子树)大于x,* 且这两段(子树)都是合法的后序序列。完美的递归定义 : */public boolean VerifySquenceOfBST(int[] sequence) {if (sequence.length == 0)return false;return judge(sequence, 0, sequence.length - 1);}private boolean judge(int[] sequence, int l, int r) {
//		if(l>=r) return true;
//		int mid = l;
//		while(sequence[mid++]<sequence[r]&&mid<r);
//		
//		int tmp = mid;
//		while(sequence[tmp++]>sequence[r]&&tmp<r);
//		
//		if(tmp<r){
//			return false;
//		}
//		
//		if(mid==l || tmp==r){
//			return judge(sequence, l, r-1);
//		}else{
//			return (judge(sequence,l,mid-1)&&judge(sequence, mid+1, r-1));
//		}if(l>=r) return true;int i = r;//以右子树的条件,找到左子树的根i-1while(i>l&&sequence[i-1]>sequence[r]) --i;//判断左子树是否都小于根for(int j=i-1;j>=l;--j) if(sequence[j]>sequence[r]) return false;return judge(sequence, l, i-1) && judge(sequence, i, r-1);}
}


这篇关于剑指offer:(23)举例让抽象问题具体化 :二叉搜索树的后序遍历序列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/581078

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

Python WebSockets 库从基础到实战使用举例

《PythonWebSockets库从基础到实战使用举例》WebSocket是一种全双工、持久化的网络通信协议,适用于需要低延迟的应用,如实时聊天、股票行情推送、在线协作、多人游戏等,本文给大家介... 目录1. 引言2. 为什么使用 WebSocket?3. 安装 WebSockets 库4. 使用 We

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异