判定一棵二叉树是否是二叉搜索树
来源:互联网 发布:java连接ssh的jar包 编辑:程序博客网 时间:2024/06/08 18:49
问题
给定一棵二叉树,判定该二叉树是否是二叉搜索树(Binary Search Tree)?
解法1:暴力搜索
首先说明一下二叉树和二叉搜索树的区别。二叉树指这样的树结构,它的每个结点的孩子数目最多为2个;二叉搜索树是一种二叉树,但是它有附加的一些约束条件,这些约束条件必须对每个结点都成立:
- 结点node的左子树所有结点的值都小于node的值。
- 结点node的右子树所有结点的值都大于node的值。
- 结点node的左右子树同样都必须是二叉搜索树。
该问题在面试中也许经常问到,考察的是对二叉搜索树定义的理解。初看这个问题,也许会想这样来实现:
假定当前结点值为k。对于二叉树中每个结点,判断其左孩子的值是否小于k,其右孩子的值是否大于k。如果所有结点都满足该条件,则该二叉树是一棵二叉搜索树。
很不幸的是,这个算法是错误的。考虑下面的二叉树,它符合上面算法的条件,但是它不是一棵二叉搜索树。
10 / \ 5 15 -------- binary tree (1) / \ 6 20那么,根据二叉搜索树的定义,可以想到一种暴力搜索的方法来判定二叉树是否为二叉搜索树。
假定当前结点值为k。则对于二叉树中每个结点,其左子树所有结点的值必须都小于k,其右子树所有结点的值都必须大于k。
暴力搜索算法代码如下,虽然效率不高,但是它确实能够完成工作。该解法最坏情况复杂度为O(n^2),n为结点数目。(当所有结点都在一边的时候出现最坏情况)解法2:更好的解法
以前面提到的binary tree(1)为例,当我们从结点10遍历到右结点15时,我们知道右子树结点值肯定都在10和+INFINITY(无穷大)之间。当我们遍历到结点15的左孩子结点6时,我们知道结点15的左子树结点值都必须在10到15之间。显然,结点6不符合条件,因此它不是一棵二叉搜索树。该算法代码如下:
解法3:中序遍历算法
因为一棵二叉搜索树的中序遍历后其结点值是从小到大排好序的,所以依此给出下面的解法。该解法时间复杂度也是O(n)。
阅读全文
0 0
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 【IT笔试面试题整理】判定一棵二叉树是否是二叉搜索树-转
- 判断一棵二叉树,是否是搜索二叉树
- 【BST】判断一棵二叉树是否是搜索二叉树
- 判断一棵二叉树是否是完全二叉树
- 判断一棵二叉树是否是完全二叉树
- 判断一棵二叉树是否是平衡二叉树
- 判定两棵二叉树是否同构
- 求二叉树的深度,判定二叉树是否是平衡二叉树(java)
- 判断一棵树是否是二叉搜索树
- 判断是否是搜索二叉树
- 面试经典(15)--判定是否是平衡二叉树
- 判定二叉树是否是BST 递归版本
- 目前拥有的资源
- Flume的安装部署
- HDU 2492
- 【转】一文读懂数据分析平台的架构与设计
- MxNet使用总览
- 判定一棵二叉树是否是二叉搜索树
- SpringBoot整合Redis
- HDU 4771 Stealing Harry Potter's Precious
- CSS3有哪些新增的选择器?
- ACdream 1417
- 287. Find the Duplicate Number
- BackTrack5 学习笔记6 SNMP
- MOOC清华《面向对象程序设计》第3章:函数运算符重载实验
- HDU 5835 Danganronpa (贪心)