题目描述:
输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
思路:儿叉搜索树:(二叉排序树) 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值; 它的左、右子树也分别为二叉排序树。(左<根,右>根)
即:后序序列最后一个值为root;二叉搜索树左子树值都比root小,右子树值都比root大。
1、确定root;
2、遍历序列(除去root结点),找到第一个大于root的位置,则该位置左边为左子树,右边为右子树;
3、遍历右子树,若发现有小于root的值,则直接返回false;
4、分别判断左子树和右子树是否仍是二叉搜索树(即递归步骤1、2、3)。
代码说明:用index来区分根节点的左右子树。
# -*- coding:utf-8 -*-
class Solution:
def VerifySquenceOfBST(self, sequence):
# write code here
length = len(sequence)
if not sequence:
return False
if length<2:
return True
root = sequence[-1]
index = 0
i=0
while sequence[i]<root:
i=i+1
index = i
for j in range(i, length-1):
if sequence[j] < root:
return False
left = sequence[:index]
right = sequence[index:-1]
result = True
if left:
result = self.VerifySquenceOfBST(left)
if right:
result = result and self.VerifySquenceOfBST(right)
return result