剑指offer JZ33 二叉搜索树的后序遍历序列

描述

剑指offer JZ33 二叉搜索树的后序遍历序列

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

数据范围: 节点数量 0≤n≤1000 ,节点上的值满足 1≤val≤105保证节点上的值各不相同

提示:

1.二叉搜索树是指父亲节点大于左子树中的全部节点,但是小于右子树中的全部节点的树。

2.该题我们约定空树不是二叉搜索树

3.后序遍历是指按照 "左子树-右子树-根节点" 的顺序遍历

方法:逆序遍历+栈

思路:

后序遍历的顺序是:左子树 ---> 右子树 ---> 根节点。那么其逆序便为:根节点 ---> 右子树 ---> 左子树。我们逆序遍历,如果是后一个节点大于前一个节点,说明后一个节点是前一个节点的右节点。并且我们每遍历一个节点就将其压入栈中。当我们发现后一个节点小于前一个节点,说明前一个节点没有右节点了,并且后一个节点是前一个节点(或者前一个节点的父节点)的左节点,那么我们就通过栈找到后一个节点的父节点,并且以后的节点都只能比这个节点小。

具体实现及注释:

java 复制代码
import java.util.*;
public class Solution {

   public boolean VerifySquenceOfBST(int [] sequence) {
       int length = sequence.length;
       //空树不是二叉搜索树
       if (length == 0) return false;
       //实例化栈
       Deque<Integer> stack = new ArrayDeque<>();
       //初始化根节点,因为树中最大值为100000,所以初始化一个最大虚拟值,相当于把原树的根节点作为此虚拟节点的左节点。
       int rootValue = 100001;
       for (int i = length-1; i >= 0; i--) {
           int curValue = sequence[i];
           //因为rootValue存的是根节点的值,而curValue一定在其左子树,所以当curValue大于rootValue时,说明其不是二叉搜索树。
           if (curValue > rootValue) return false;
           //当curValue小于其前一个节点时,说明curValue不是其前一个节点的右节点,我们通过栈找到curValue的父节点,并更新rootValue
           while (!stack.isEmpty() && curValue < stack.peek()) {
               rootValue = stack.pop();
           }
           stack.push(curValue);
       }
       return true;
   }
}
相关推荐
Misnearch几秒前
1、数组/字符串
java·数据结构·算法
☆cwlulu3 分钟前
Linux系统调用与C库I/O的底层奥秘
java·spring boot·spring
008爬虫实战录14 分钟前
【数据结构】 树、二叉树、完全二叉树,先序遍历、中序遍历、后序遍历
数据结构·算法
小O的算法实验室16 分钟前
2024年AST,基于费马点分组粒子群算法的复合型无人机统一路径规划
算法·无人机
于先生吖28 分钟前
前后端分离人事招聘项目,校招宣讲预约+社招双向撮合功能架构设计教程
java·开发语言·uni-app
user_admin_god29 分钟前
Claude Code 安装与配置指南:兼容国产模型,禁止自动更新
java·人工智能
AllData公司负责人31 分钟前
大模型赋能AllData数据中台,系列升级|通过联合智谱大模型与BiSheng开源项目,建设企业大模型应用开发平台,支持知识库向量检索!
大数据·数据结构·数据库·算法·大模型·向量数据库·智谱ai
一个王同学37 分钟前
从零到一 | CV转多模态大模型 | week12 | 整理 MiniLLaVA 工程与文档
人工智能·深度学习·算法·机器学习·计算机视觉
一只鹿鹿鹿42 分钟前
网络安全评估方案
java·大数据·运维·物联网·web安全
码界索隆44 分钟前
Python转Java系列:作者有话说
java·开发语言·python