每天一道剑指offer-二叉搜索树的后序遍历序列

每天一道剑指offer-二叉搜索树的后序遍历序列_第1张图片


前言

今天的题目
每天的题目见github(看最新的日期):
https://github.com/gzc426
具体的题目可以去牛客网对应专题去找。

昨天的题解

题目

每天一道剑指offer-二叉搜索树的后序遍历序列
来源:
https://www.nowcoder.com/practice/a861533d45854474ac791d90e447bafd?tpId=13&tqId=11176&tPage=2&rp=2&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目详述

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

题目详解

思路

  • 递归的思想,每次去判断左子树的最右边界是不是大于右子树的最左边界,如果大于就不是,如果小于,那么就再往下递归。

代码

 
public class Solution {
   public boolean VerifySquenceOfBST(int [] sequence) {
       if(sequence.length == 0)
           return false;
       return verify(sequence,0,sequence.length-1);
   }
   public boolean verify(int [] sequence,int begin,int end)
   
{
       if(begin == end)
           return true;
       int rootValue = sequence[end];
       int leftBegin = -1;//左子树的左边界
       int leftEnd = -1;//左子树的右边界
       int rightBegin = -1;//右子树的左边界
       int rightEnd = -1;//右子树的右边界
       if(sequence[begin] < rootValue)// 说明存在左子树,二叉搜索树的性质
           leftBegin = begin;//记录左子树的左边界
       for(int i=begin;i        {
           if(sequence[i] < rootValue)//如果比根结点的值小,说明就是左子树
               leftEnd = i;//记录下来左子树的右边界,只要比根结点小,就进行记录
           else{
               if(rightBegin == -1) //记录右子树的左边界,这个条件判断只会记录一次。
                   rightBegin = i;
               rightEnd = i;//记录右子树的右边界
           }
       }
       if(rightBegin < leftEnd && rightBegin != -1)
           return false;//如果左子树的右边界 大于 右子树的左边界 就出问题了!false
       return verify(sequence,leftBegin,leftEnd) && verify(sequence,rightBegin,rightEnd);
//否则递归往下去判断
   }
}

代码截图(避免乱码)

每天一道剑指offer-二叉搜索树的后序遍历序列_第2张图片

结束语

作者乔戈里亲历2019秋招,哈工大计算机本硕,百度java工程师,欢迎大家关注我的微信公众号:程序员乔戈里,公众号有3T编程资源,以及我和我朋友(百度C++工程师)在秋招期间整理的近200M的面试必考的java与C++面经,并有每天一道leetcode打卡群与技术交流群,欢迎关注。

你可能感兴趣的:(每天一道剑指offer-二叉搜索树的后序遍历序列)