您的位置:首页 > Web前端

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

2015-05-23 12:58 120 查看
对于此题的解释,在注释中解释的十分详细,就不在此赘述。另外。。之前的一篇文章中提到了关于二叉树的详细说明,以及非递归、递归遍历二叉树的多种方法。

链接在此~二叉树之非递归遍历 漫谈二叉树之递归遍历

废话少说,代码搞起
/**
* Created by zhangshuyou on 2015/5/23.
*/

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

import java.util.Arrays;

/**
* 在后序遍历得到的序列中,最后一个数字是树的根结点的值。
* 数组前面的数字可以分为两部分,
* 第一部分是左子树结点的值,均小于根结点的值;
* 第二部分是右子树结点的值,均大于根结点的值。
*
* $$规律1:数组中第一个数字可以判断此二叉搜索树是否含有左子树
* $$规律2:当找到第一个大于数组末尾元素的值,此处为右子树和左子树的分界点
* $$规律3:然后以规律2再分解数组寻找结点
*/
public class Solution {

public boolean VerifySquenceOfBST(int [] sequence) {
if(sequence == null || sequence.length <= 0)
return false;
int root = sequence[sequence.length - 1];  //根结点的值
//二叉搜索树中,左子树的结点小于根结点
int i = 0;
for(; i < sequence.length - 1;++i){  //在去掉根元素之前寻找
if(sequence[i] > root){  //当遇到第一个大于根结点的值就停止,此时找到了左右子树的分界点
break;
}
}
//在二叉搜索树中,右子树的结点值大于根结点
int j = i;
for(; j < sequence.length - 1;j++){
if(sequence[j] < root)
return false;
}
//判断左子树是不是二叉搜索树
boolean left = true;
boolean right = true;
if(i > 0){
//当取得了左子树后,通过递归对左子树进行检查,检查的位置是数组的0 -- i。(此处需要复制数组)
left = VerifySquenceOfBST(Arrays.copyOfRange(sequence, 0, i));
}
if(i < sequence.length - 1){
//同上~ =。=
right = VerifySquenceOfBST(Arrays.copyOfRange(sequence , i , sequence.length - 1));
}
return (left && right);  //当左右子树均成立,返回true;不成立返回false。
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: