二叉搜索树的后序遍历序列
2015-08-07 15:35
211 查看
题目描述
输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。思路:主要是根据根节点划后序遍历数组,分出左右子树,判断左右子树和根节点值的大小是否符合二叉搜索树的大小关系,并递归判断左右子树是否为二叉搜索树。依此为依据作为判断的结果,注意left=true初始化为true,因为左子树可能为空,这样不影响判断右子树是否为二叉搜索树。
总的来说就是,判断根节点和左右是否满足二叉搜索树的特点,然后根据后序遍历序列来分别判断左右子树是否为二叉搜索树即可,如果不是,那么返回false。
代码如下:
public class Solution { public boolean VerifySquenceOfBST(int [] sequence) { if(sequence==null || sequence.length==0){ return false; } int len = sequence.length; return VerifySquenceOfBST(sequence,0,len-1); } public boolean VerifySquenceOfBST(int[] array,int start,int end){ int root = array[end]; //在二叉搜索树中左子树的结点小于根节点 int i = start; for(; i < end;i++){ if(array[i]>root) break; } //在二叉搜索树中右子树的结点大于根节点 int j = i; for(;j < end;j++){ if(array[j] < root) return false; } //判断左子树是不是二叉搜索树,如果没有左子树,就相当于左子树是真,所以left初始化为true,不影响右子树的判断结果 boolean left = true; if(i >start) left =VerifySquenceOfBST(array ,start,i-1); //判断右子树是不是二叉搜索树,如果没有右子树,就相当于右子树是真,所以right初始化为true,不影响左子树的判断结果 boolean right = true; if(i < end) right = VerifySquenceOfBST(array,i,end-1); return (left && right); } }
相关文章推荐
- RabbitMQ 入门一(下载安装)
- iOS pch文件的创建
- 实时监听textarea并限制最大字符数
- java中的toString方法
- UIScrollView实现图片浏览
- Win10第三方主题包Numix下载:将暗系风进行到底
- Linux 目录结构及文件
- 从进程到线程
- 算法导论 CLRS 2.3-7 2-2
- 过滤HTML标签
- 经典排序算法之希尔排序
- memcached并发CAS模式
- 怎么样才是理想的程序员?
- 字符串的组合算法问题的C语言实现攻略
- 【android控件学习笔记】GridView表格形式显示多张图片
- 换一种方式创建Linux下的自解压文件
- 44444444444444444444444444444444dddddddddd66666666666666666666666666
- Num 23 : HDOJ : 2199 Can you solve this equation? + HDOJ : 1969 Pie [ 二分法 ]
- 通过xshell远程连接ubuntu
- 【bzoj2393】 Cirno的完美算数教室 容斥原理