题目描述

输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。
# -*- coding:utf-8 -*-
class Solution:
def VerifySquenceOfBST(self, sequence):
# write code here
#二叉搜索树是对一个有序数组进行二分查找形成的搜索树,它指一棵空树或者具有下列性质的二叉树:
#若任意节点的左子树不空,则左子树上所有节点的值均小于它的根节点的值;
#若任意节点的右子树不空,则右子树上所有节点的值均大于它的根节点的值;
#任意节点的左、右子树也分别为二叉查找树;
if len(sequence) == 0:
return False
else:
root = sequence[-1]
del sequence[-1]
lefttree =[]
righttree =[]
#创建左子树和右子树的分界
splitindex = -1
for i in range(len(sequence)):
#值小于根结点的归为左子树
if sequence[i] < root:
lefttree.append(sequence[i])
splitindex = i
else:
break
for i in range(splitindex+1, len(sequence)):
# 若右子树部分有小于根结点的值,说明不是二叉搜索树
if sequence[i] > root:
righttree.append(sequence[i])
else:
return False
if len(lefttree) <= 1:
left = True
else:
# 递归判断左子树
left = self.VerifySquenceOfBST(lefttree)
if len(righttree) <= 1:
right = True
else:
right = self.VerifySquenceOfBST(righttree)
return left and right

  

最新文章

  1. c++单链表基本功能
  2. VS2013单元测试 的安装、创建与执行
  3. 25款响应式,支持视网膜显示的 Wordpress 主题
  4. 洛谷P1538迎春舞会之数字舞蹈
  5. findstr 命令
  6. 判断文件夹下是否存在txt格式的文本文件
  7. 关于THIS_FILE
  8. c/c++优秀博文
  9. Winform DataGridView单元格的提示信息
  10. Nginx 第三方模块-漫谈缘起
  11. 3 linux、windows环境---路径分隔符不同导致的问题
  12. (升级版)Spark从入门到精通(Scala编程、案例实战、高级特性、Spark内核源码剖析、Hadoop高端)
  13. MySQL SQL优化——分片搜索
  14. Docker aufs存储驱动layer、diff、mnt目录的区别
  15. 【转】Robust regression(稳健回归)
  16. 标准Http协议的六种请求方法详解
  17. Docker配置 DNS
  18. Linux之文件权限
  19. node,npm,vue的全局升级
  20. SpringBoot的学习【7.引入配置文件】

热门文章

  1. JQuery:聚焦清空输入框值,失焦恢复默认值
  2. 17. 判断是否IE浏览器
  3. PHP AES加密解密。
  4. 复习 HTML
  5. Android Data Binding Library
  6. linux 显示系统执行的进程
  7. Jmeter的安装与使用
  8. Linux 多进程实现方法
  9. KVM虚拟化技术(三)KVM环境预配
  10. VC/VS2010中快捷键