剑指Offer-->二叉搜索树的后序遍历序列
来源:互联网 发布:python 定时发送邮件 编辑:程序博客网 时间:2024/05/21 11:28
对于此题的解释,在注释中解释的十分详细,就不在此赘述。另外。。之前的一篇文章中提到了关于二叉树的详细说明,以及非递归、递归遍历二叉树的多种方法。
链接在此~二叉树之非递归遍历 漫谈二叉树之递归遍历
废话少说,代码搞起
/** * 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。 }}
0 0
- 剑指offer:二叉搜索树的后序遍历序列
- 【剑指offer】二叉搜索树的后序遍历序列
- 剑指offer--二叉搜索树的后序遍历序列
- 剑指Offer-->二叉搜索树的后序遍历序列
- 《剑指offer》二叉搜索树的后序遍历序列
- 【剑指Offer】二叉搜索树的后序遍历序列
- 剑指offer--二叉搜索树的后序遍历序列
- 剑指 offer:二叉搜索树的后序遍历序列
- 剑指offer:二叉搜索树的后序遍历序列
- 【剑指offer】二叉搜索树的后序遍历序列
- 二叉搜索树的后序遍历序列||剑指offer
- 剑指offer-二叉搜索树的后序遍历序列
- 剑指offer 二叉搜索树的后序遍历序列
- 剑指offer 二叉搜索树的后序遍历序列
- 剑指offer:二叉搜索树的后序遍历序列
- [剑指offer]二叉搜索树的后序遍历序列
- 《剑指offer》-二叉搜索树的后序遍历序列
- 【剑指offer】二叉搜索树的后序遍历序列
- 最长回文子字符串
- 欢迎使用CSDN-markdown编辑器
- Ubuntu下同时安装了python2版本和python3版本如何使用pip分别为P2和P3安装不同类库
- sudo: /usr/lib/sudo/sudoers.so must be owned by uid 0
- Mysql 触发器
- 剑指Offer-->二叉搜索树的后序遍历序列
- 文本语言模型的参数估计-最大似然估计、MAP及贝叶斯估计
- 数据库第4个实验工作量蛮大的
- https://leetcode.com/problems/search-for-a-range/
- 【原创】wince bluebooth设备编程札记
- HTML5新特性之Communication
- UITabeViews---设置字体格式,大小,颜色
- 用例规约
- Linux tar 解压命令总结