美文网首页皮皮的LeetCode刷题库
【剑指Offer】023——二叉搜索树的后序遍历序列(栈、树)

【剑指Offer】023——二叉搜索树的后序遍历序列(栈、树)

作者: 就问皮不皮 | 来源:发表于2019-08-19 12:05 被阅读1次

    题目描述

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

    解题思路

    二叉搜索树(值): 左子树 < 根 < 右子树

    对于后序遍历来说,序列数组的最后一个元素一定是根节点, 根据这个元素,将前面的数组分为左、右两个部分,左侧部分都比该元素小,右侧部分都比该元素大,如果右侧部分有比该根节点小的元素,那么就不是后序遍历,如此递归进行。

    参考代码

    Java

    public class Solution {
        public boolean VerifySquenceOfBST(int[] sequence) {
            if (sequence.length == 0)
                return false;
            if (sequence.length == 1)
                return true;
            // 输入序列,序列开始和结束位置
            return judge(sequence, 0, sequence.length - 1);
        }
    
        public boolean judge(int[] sequence, int start, int root) {
            // 递归结束标记
            if (start >= root) {
                return true;
            }
            int i = start; // 序列开始
            // 根大于左子树 小于右子树,找根节点
            while (i < root && sequence[i] < sequence[root]) {
                i++;
            }
            // 检查右子树的数据
            for (int j = i; j < root; j++) {
                if (sequence[j] < sequence[root])
                    return false;
            }
            return judge(sequence, start, i - 1) && judge(sequence, i, root - 1);
        }
    }
    

    Python

    # -*- coding:utf-8 -*-
    class Solution:
        def VerifySquenceOfBST(self, sequence):
            if len(sequence) == 0:return False
            if len(sequence) == 1: return True
            return self.judge(sequence, 0, len(sequence) - 1)
        def judge(self,sequence, start, root):
            if start >= root:
                return True
            index = start
            while index < root and sequence[index] < sequence[root]:
                index += 1
            for i in range(index, root):
                if sequence[i] < sequence[root]: return False
            return self.judge(sequence,start,index - 1) and self.judge(sequence, index, root -1)
    

    个人订阅号

    image

    相关文章

      网友评论

        本文标题:【剑指Offer】023——二叉搜索树的后序遍历序列(栈、树)

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