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

xiaoxiao2021-02-28  112

题目描述

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

二叉搜索树:根节点的值大于左节点的值,小于右节点的值;

后序遍历:按照左右根节点的顺序遍历二叉树;

/*首先,二叉搜索树,左子树值小于根节点,有子树值大于根节点 * 然后后序遍历是左右根的顺序----递归*/ public class 二叉搜索树的后序遍历序列 { public static void main(String[] args) { // TODO Auto-generated method stub } public boolean VerifySquenceOfBST(int [] sequence) { if (sequence.length==0) { return false; } return judge(sequence,0,sequence.length-1); } private boolean judge(int[] sequence, int start, int end) { // TODO Auto-generated method stub if (start>=end) { return true;//结束条件, } int i = start; for (; i < end; i++) { if (sequence[i]>sequence[end]) { break; } } int j = i; for (; j < end; j++) { if (sequence[j]<sequence[end]) { break; } } if (j==end) { return judge(sequence, start, i-1)&&judge(sequence, j, end-1); }else { return false; } } }

转载请注明原文地址: https://www.6miu.com/read-50304.html

最新回复(0)