【剑指Offer】33.二叉搜索树的后序遍历序列

题目

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

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

要求:空间复杂度 O(n) ,时间时间复杂度 O(n2)

提示:

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

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

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

4.参考下面的二叉搜索树,示例 1

示例1

输入:[1,3,2]

返回值:true

说明:是上图的后序遍历 ,返回true

示例2

输入:[3,1,2]

返回值:false

说明:不属于上图的后序遍历,从另外的二叉搜索树也不能后序遍历出该序列 ,因为最后的2一定是根节点,前面一定是孩子节点,可能是左孩子,右孩子,根节点,也可能是全左孩子,根节点,也可能是全右孩子,根节点,但是[3,1,2]的组合都不能满足这些情况,故返回false

示例3

输入:[5,7,6,9,11,10,8]

返回值:true

解答

源代码

java 复制代码
import java.util.*;
public class Solution {
    public boolean VerifySquenceOfBST(int [] sequence) {
        if (sequence.length == 0) {
            return false;
        }

        return judge(sequence, 0, sequence.length - 1);
    }

    public boolean judge(int[] sequence, int left, int right) {
        if (left >= right) {
            return true;
        }

        int i = 0;
        while (i < right && sequence[i] < sequence[right]) {
            i++;
        }

        for (int j = i; j < right; j++) {
            if (sequence[j] < sequence[right]) {
                return false;
            }
        }

        return judge(sequence, left, i - 1) &&  judge(sequence, i, right - 1);
    }
}

总结

设计一个函数,传入一个整数数组和左右边界,判断左右边界之间的序列能否构成一个二叉搜索树的后序遍历序列。

后序遍历序列的最后一个数字一定是根结点,那么从头遍历这个序列,找出连续的小于根结点的数字作为左子树的后序遍历序列,接下来判断余下将要作为右子树的序列中是否小于根结点的数字,若有,则无返回false。之后递归判断左右子树的数组能否构成后序遍历序列,只有两个都返回true时,整个数组才为二叉搜索树的后序遍历序列。

相关推荐
chengooooooo14 分钟前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
李长渊哦16 分钟前
常用的 JVM 参数:配置与优化指南
java·jvm
计算机小白一个17 分钟前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^1 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
大数据追光猿3 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!3 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉3 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生3 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴3 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing3 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode