美文网首页
剑指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