二叉搜索树的后序遍历序列
来源:互联网 发布:在淘宝怎么开店啊 编辑:程序博客网 时间:2024/06/03 16:50
题目描述
输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出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); }}
0 0
- 二叉树------二叉搜索树的后序遍历序列
- 【树5】二叉搜索树的后序遍历序列
- 题目10:二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 题目1367:二叉搜索树的后序遍历序列
- 1367:二叉搜索树的后序遍历序列 @jobdu
- 二叉搜索树的后序遍历序列
- Q24:二叉搜索树的后序遍历序列
- 剑指offer:二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 【剑指offer】二叉搜索树的后序遍历序列
- 题目1367:二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列
- 内支付四: AppStore苹果应用支付开发(In App Purchase)翻译
- 深入浅出 JavaScript 中的 this
- .PHONY makefile中的伪目标
- HDU - 1014 - Uniform Generator
- linux下svn的常用指令
- 二叉搜索树的后序遍历序列
- (三) Build Task(构建任务)
- 加密解密的一些方法
- 科_工作笔记_1
- LoadRunner脚本语言之C语言
- Linux基础正则表达式字符汇整(characters)
- body的margin问题。
- hdu5353(2015多校6)--Average(贪心)
- SDUOJ---2109找女朋友