二叉搜索树的后序遍历序列(python)
2024-09-20 20:19:39
题目描述
输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出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
最新文章
- c++单链表基本功能
- VS2013单元测试 的安装、创建与执行
- 25款响应式,支持视网膜显示的 Wordpress 主题
- 洛谷P1538迎春舞会之数字舞蹈
- findstr 命令
- 判断文件夹下是否存在txt格式的文本文件
- 关于THIS_FILE
- c/c++优秀博文
- Winform DataGridView单元格的提示信息
- Nginx 第三方模块-漫谈缘起
- 3 linux、windows环境---路径分隔符不同导致的问题
- (升级版)Spark从入门到精通(Scala编程、案例实战、高级特性、Spark内核源码剖析、Hadoop高端)
- MySQL SQL优化——分片搜索
- Docker aufs存储驱动layer、diff、mnt目录的区别
- 【转】Robust regression(稳健回归)
- 标准Http协议的六种请求方法详解
- Docker配置 DNS
- Linux之文件权限
- node,npm,vue的全局升级
- SpringBoot的学习【7.引入配置文件】