This theme |

Tiory

园龄:4年6个月粉丝:1关注:5

二叉搜索树的后序遍历序列

二叉搜索树的后序遍历序列

题目描述

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

image-20200815205244055

分析:

image-20200815205646427

image-20200815205652606

代码实现:

image-20200815205159665

public class Solution {
    public boolean VerifySquenceOfBST(int [] sequence) {
        if(sequence.length==0){
            return false;
        }
        return Verify(sequence,0,sequence.length-1);
    }
    public boolean Verify(int[] sequence,int start,int end){
        if(start>=end){
            return true;
        }
        int i=start;
        while(sequence[i]<sequence[end]){
            i++;
        }
        for(int j=i;j<end;j++){
            if(sequence[j]<sequence[end]){
                return false;
            }
        }
        return Verify(sequence,start,i-1)&&Verify(sequence,i,end-1);
    }
}

问题总结

在调试过程中,传入的测试数据:

image-20200815210118694

在向左递归的时候,然后再回溯的时候start=1了,这是为什么

image-20200815210046649

这是测试代码

psvm

public static void main(String[] args) {
//        String str = "ab";
        int[] arr = {1, 4, 2, 6, 11, 9, 5};
        boolean r = VerifySquenceOfBST(arr);
        System.out.println(r);



    }

主代码:

  public static boolean VerifySquenceOfBST(int [] sequence) {
        if(sequence.length==0){
            return false;
        }
        return Verify(sequence,0,sequence.length-1);
    }
    public static boolean Verify(int[] sequence,int start,int end){
        if(start>=end){
            return true;
        }
        int i=start;
        while(sequence[i]<sequence[end]){
            i++;
        }
        for(int j=i;j<end;j++){
            if(sequence[j]<sequence[end]){
                return false;
            }
        }
        return Verify(sequence,start,i-1)&&Verify(sequence,i,end-1);
    }

本文作者:Tiory

本文链接:https://www.cnblogs.com/SunAlbert/p/13510333.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   Tiory  阅读(192)  评论(1编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起
  1. 1 404 not found REOL
404 not found - REOL
00:00 / 00:00
An audio error has occurred.

作曲 : Reol

作词 : Reol

fade away...do over again...

fade away...do over again...

歌い始めの一文字目 いつも迷ってる

歌い始めの一文字目 いつも迷ってる

どうせとりとめのないことだけど

伝わらなきゃもっと意味がない

どうしたってこんなに複雑なのに

どうしたってこんなに複雑なのに

噛み砕いてやらなきゃ伝わらない

ほら結局歌詞なんかどうだっていい

僕の音楽なんかこの世になくたっていいんだよ

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

僕は気にしない 君は気付かない

何処にももういないいない

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

忘れていく 忘れられていく

We don't know,We don't know.

目の前 広がる現実世界がまた歪んだ

目の前 広がる現実世界がまた歪んだ

何度リセットしても

僕は僕以外の誰かには生まれ変われない

「そんなの知ってるよ」

気になるあの子の噂話も

シニカル標的は次の速報

麻痺しちゃってるこっからエスケープ

麻痺しちゃってるこっからエスケープ

遠く遠くまで行けるよ

安定なんてない 不安定な世界

安定なんてない 不安定な世界

安定なんてない きっと明日には忘れるよ

fade away...do over again...

fade away...do over again...

そうだ世界はどこかがいつも嘘くさい

そうだ世界はどこかがいつも嘘くさい

綺麗事だけじゃ大事な人たちすら守れない

くだらない 僕らみんなどこか狂ってるみたい

本当のことなんか全部神様も知らない

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

僕は気にしない 君は気付かない

何処にももういないいない

Everybody don't know why.

Everybody don't know why.

Everybody don't know much.

忘れていく 忘れられていく

We don't know,We don't know.