* 21【题目】输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。
*      如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
*    【注】二叉搜索树特点:左子树比根结点值小,右子树比根结点值大。
*    【思路】①根据后序遍历结果确定根结点;
*     ②判断所有左子树是否比根结点值小;
*     ③判断所有右子树是否比根结点值大;
    * ④使用递归,继续分别判断左右子树中是否符合这一特点。

package com.exe5.offer;

/**
* 21【题目】输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。
* 如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
* 【注】二叉搜索树特点:左子树比根结点值小,右子树比根结点值大。
* 【思路】①根据后序遍历结果确定根结点;
* ②判断所有左子树是否比根结点值小;
* ③判断所有右子树是否比根结点值大;
* ④使用递归,继续分别判断左右子树中是否符合这一特点。
* @author WGS
*
*/
public class VerifySequenceOfBST { public boolean verifySequenceOfBST(int[] arrOfPostOrder){
if(arrOfPostOrder==null) return false;
int len=arrOfPostOrder.length;//
System.out.println("len:"+len);//
int rootVal=arrOfPostOrder[len-1];//根据后序遍历结果得到根结点值
//判断左子树(<根结点值)
int i=0;
for(;i<len-1;i++){//
if(arrOfPostOrder[i]>rootVal)
break;
}
System.out.println(i);//3
//判断右子树(>根结点值)
for(int j=i;j<len-1;j++){
if(arrOfPostOrder[j]<rootVal)
return false;
}
//继续判断左子树
int[] leftTree=new int[(len-1)/2];//
System.arraycopy(arrOfPostOrder, 0, leftTree, 0, (len-1)/2);
boolean leftFlag=true;
if(i>0){
leftFlag=verifySequenceOfBST(leftTree);
}
//继续判断右子树
int[] rightTree=new int[(len-1)/2];//需要注意到的是此处建立数组时长度是在不断发生变化的
System.arraycopy(arrOfPostOrder, (len-1)/2, leftTree, 0,len-i-1);
boolean rightFlag=true;
if(i<arrOfPostOrder.length-1){
rightFlag=verifySequenceOfBST(rightTree);
} return leftFlag&&rightFlag; }
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] arr=new int[]{5,7,6,9,11,10,8};
System.out.println(new VerifySequenceOfBST().verifySequenceOfBST(arr));
} }

剑指offer系列21--二叉搜索树的后续遍历序列的更多相关文章

  1. 剑指offer系列——62.二叉搜索树的第k个结点

    Q:给定一棵二叉搜索树,请找出其中的第k小的结点.例如, (5,3,7,2,4,6,8) 中,按结点数值大小顺序第三小结点的值为4. T: 中序遍历,递归: int count = 0; public ...

  2. 剑指 Offer 68 - I. 二叉搜索树的最近公共祖先 + 二叉排序树 + 最近公共祖先

    剑指 Offer 68 - I. 二叉搜索树的最近公共祖先 Offer_68_1 题目描述 方法一:迭代法 由于该题的二叉树属于排序二叉树,所以相对较简单. 只需要判断两个结点是否在根节点的左右子树中 ...

  3. 剑指 Offer 68 - I. 二叉搜索树的最近公共祖先

    剑指 Offer 68 - I. 二叉搜索树的最近公共祖先 给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先. 百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p.q ...

  4. 刷题-力扣-剑指 Offer II 055. 二叉搜索树迭代器

    剑指 Offer II 055. 二叉搜索树迭代器 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/kTOapQ 著作权归领扣网络所有 ...

  5. 剑指offer 24:二叉搜索树的后序遍历序列

    题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 解题思路 后序遍历,顾名思义根节点位于尾部,故可将 ...

  6. 剑指OFFER之从二叉搜索树的后序遍历序列(九度OJ1367)

    题目描述: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 输入: 每个测试案例包括2行: 第一行为1个整数 ...

  7. 剑指offer:二叉搜索树的后续遍历序列

    题目描述: 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同. 解题思路: 根据二叉搜索的性质,后序遍历是先搜索 ...

  8. 剑指offer之 二叉搜索树的后续遍历序列

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

  9. 剑指offer 27:二叉搜索树与双向链表

    题目描述 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向. 解题思路 采用中序遍历遍历二叉树,利用二叉排序树的特性,顺次连接节点,形成 ...

  10. 剑指offer 面试题. 二叉搜索树的第k个结点

    题目描述 给定一棵二叉搜索树,请找出其中的第k小的结点.例如, (5,3,7,2,4,6,8)    中,按结点数值大小顺序第三小结点的值为4.     解: 由于二叉搜索树的中序遍历是升序,所以在中 ...

随机推荐

  1. 在Python中,令values=[0,1,2];values[1]=values,为何结果是[0,[...],2]?

    转载自:http://www.zhihu.com/question/21000872/answer/16856382>>> values = [0, 1, 2] >>&g ...

  2. oc小总结

    oc的一些总结 下面几个问题是oc中需要掌握的内容 1.如何掌握一个方法的方法名 2.一个对象调用一个autorelease,什么时候释放 3.字典和数组,集合都有什么特点 4.如何定义一个类 5.类 ...

  3. js图片无缝滚动代码

    想必大家都注意到<marquee>的不循环滚动,所以出现了很多替代脚本,或iframe或JS输出<marquee>,不管怎么做,都略显麻烦.下面说一下这个相对简单的实现思路:一 ...

  4. ASP.NET Web API与Rest web api(一)

    本文档内容大部分来源于:http://www.cnblogs.com/madyina/p/3381256.html HTTP is not just for serving up web pages. ...

  5. Mvc3.0_笔记

    1.保留文本框中的值:<p>Find @Html.TextBox("searchKey", ViewBag.Filter as string)</p>  这 ...

  6. C函数及指针学习1

    1 大段程序注释的方法 #if 0#endif 2三字母词 以两个问号 开始的都要注意 3 字面值(常量) 在整型号字面值后加 字符L (long),U(unsigned)说明字符常量 为长整型 或( ...

  7. 工作中遇到的问题--BindException

    org.springframework.validation.BindException: org.springframework.validation.BeanPropertyBindingResu ...

  8. spark新能优化之shuffle新能调优

    shuffle调优参数 new SparkConf().set("spark.shuffle.consolidateFiles", "true") spark. ...

  9. IOS中使用手机号注册

    #import <Foundation/Foundation.h>#import <UIKit/UIKit.h>@interface KCVVerify : NSObject ...

  10. GDI+中GIF图片的显示

    某位网友曾经问过我GDI+中Gif图像显示的问题,一直没时间给你写,在此致歉.我把这篇文章送给他. 一.GIF格式介绍 1.概述 GIF(Graphics Interchange Format,图形交 ...