zoukankan      html  css  js  c++  java
  • 剑指 Offer 33. 二叉搜索树的后序遍历序列

    class Solution {
        public boolean verifyPostorder(int[] postorder) {
            return verifySquenceofBST(postorder,0,postorder.length-1);
        }    
    
        boolean verifySquenceofBST(int[] sequence ,int start,int end){
                //如果left==right,就一个节点不需要判断了,如果left>right说明没有节点,
                //也不用再看了,否则就要继续往下判断
                if(start >= end) return true;
                //因为数组中最后一个值postorder[right]是根节点,这里从左往右找出第一个比
                //根节点大的值,他后面的都是根节点的右子节点(包含当前值,不包含最后一个值,
                //因为最后一个是根节点),他前面的都是根节点的左子节点
                int root = sequence[end];
                int mid = start;  
                while(sequence[mid] < root){
                    mid++;
                } 
                int tmp = mid;
                //因为postorder[mid]前面的值都是比根节点root小的,
                //我们还需要确定postorder[mid]后面的值都要比根节点root大,
                //如果后面有比根节点小的直接返回false
                while(tmp < end){
                    if(sequence[tmp++] < root){
                        return false;
                    }
                }
                //然后对左右子节点进行递归调用
                return verifySquenceofBST(sequence,start,mid-1) && verifySquenceofBST(sequence,mid,end-1);
                }
        
    }
  • 相关阅读:
    脚本,网络配置,指令
    拦截TextBox 双击消息
    VB指针操作和消息钩子
    文件和文件夹操作
    常见反编译产生错误 k__BackingField 解决办法
    关机/重启/注销
    通用命名前缀
    语言区域代码
    常用数据库链接字符串
    用VB实现COM+组件配置
  • 原文地址:https://www.cnblogs.com/peanut-zh/p/14139445.html
Copyright © 2011-2022 走看看