美文网首页
剑指offer之二叉搜索树的后序遍历序列

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

作者: 阿祥小王子 | 来源:发表于2018-11-15 20:26 被阅读0次

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

    欢迎关注作者简书
    csdn传送门

    题目

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

    二叉树三种遍历方式

    1. 先序遍历
      先序遍历先从二叉树的根开始,然后到左子树,再到右子树
    2. 中序遍历
      中序遍历先从左子树开始,然后到根,再到右子树
    3. 后序遍历
      后序遍历先从左子树开始,然后到右子树,再到根

    思路

    二叉搜索树的特点是左子树比根结点小,右子树比根结点大。后序遍历最后一个元素是根结点,根结点左边的元素都比根结点小,根结点右边的元素都比根结点大。

    /**
     * @program:
     * @description:
     * @author: zhouzhixiang
     * @create: 2018-11-14 18:41
     */
    public class Test23 {
    
        public static boolean verifySequenceOfBST(int[] sequence) {
            if(sequence == null || sequence.length <= 0) return false;
            return verifySequenceOfBST(sequence, 0, sequence.length - 1);
        }
    
        /**
         * 后序遍历,先左子树,然后根节点,然后右子树
         * @param sequence
         * @param start
         * @param end
         * @return
         */
        private static boolean verifySequenceOfBST(int[] sequence, int start, int end) {
            // 要处理的数据只有一个,或者没有要处理的数据了
            if(start >= end) return true;
            // 从左向右找第一个大于根节点的元素的位置
            int index = start;
            while (index < end - 1 && sequence[index] < sequence[end]) index++;
            // 执行到此处[start, index-1]的元素都是小于根节点的
            // right用来记录第一个不小于根节点的元素的位置
            int right = index;
            while (index < end - 1 && sequence[index] > sequence[end]) index++;
            // 如果index不等于end-1,说明右子树数据中有不大于根节点的数据,不成立
            if(index != end - 1) return false;
            // 执行到此,目前数据还是合法的
            index = right;
            return verifySequenceOfBST(sequence, start, index - 1) && verifySequenceOfBST(sequence, index, end - 1);
        }
    }
    

    欢迎加入Java猿社区

    欢迎加入Java猿社区.png

    相关文章

      网友评论

          本文标题:剑指offer之二叉搜索树的后序遍历序列

          本文链接:https://www.haomeiwen.com/subject/jejufqtx.html