[互联网面试笔试汇总C/C++-14] 判断一棵二叉树是否是二叉搜索树-微策略
来源:互联网 发布:windows凭据 普通凭据 编辑:程序博客网 时间:2024/05/22 03:40
首先看一下二叉搜索树的定义:
或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值; 它的左、右子树也分别为二叉排序树。
原理:一棵二叉搜索树的中续遍历结果是从小到大排序好的,反之亦然。
代码:时间复杂度O(n),空间复杂度O(1)
- bool isBSTInOrder(BinaryTree *root)
- {
- int prev = INT_MIN;
- return isBSTInOrderHelper(root, prev);
- }
- /*该函数判断二叉树p是否是一棵二叉搜索树,且其结点值都大于prev*/
- bool isBSTInOrderHelper(BinaryTree *p, int& prev)
- {
- if (!p) return true;
- if (isBSTInOrderHelper(p->left, prev)) { // 如果左子树是二叉搜索树,且结点值都大于prev
- if (p->data > prev) { //判断当前结点值是否大于prev,因为此时prev已经设置为已经中序遍历过的结点的最大值。
- prev = p->data;
- return isBSTInOrderHelper(p->right, prev); //若结点值大于prev,则设置prev为当前结点值,并判断右子树是否二叉搜索树且结点值都大于prev。
- } else {
- return false;
- }
- }
- else {
- return false;
- }
- }
如果觉得上面的思路不好理解,可以先对二叉搜索树进行中序遍历,然后将遍历结果存放到一个数组中,然后判断这个数组是否是从小到大排好序,而且无重复元素的。时间复杂度O(n),空间复杂度O(n).
- [互联网面试笔试汇总C/C++-14] 判断一棵二叉树是否是二叉搜索树-微策略
- [互联网面试笔试汇总C/C++-15] 判断一棵二叉树是否是完全搜索树-微策略
- [互联网面试笔试汇总C/C++-16] 判断一棵二叉树是否是平衡二叉树
- 判断一棵二叉树,是否是搜索二叉树
- 【IT笔试面试题整理】判定一棵二叉树是否是二叉搜索树-转
- 【BST】判断一棵二叉树是否是搜索二叉树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 判定一棵二叉树是否是二叉搜索树
- 笔试面试算法经典--判断二叉树是否是平衡二叉树(Java)
- 判断一棵二叉树是否是完全二叉树
- 判断一棵二叉树是否是完全二叉树
- 判断一棵二叉树是否是平衡二叉树
- 判断一棵树是否是二叉搜索树
- 判断是否是搜索二叉树
- Duilib中各个类的简单介绍
- linux网络协议栈4
- 动态Linq的逻辑与和逻辑或的条件查询
- ibm cognos 10 for linux安装步骤
- #import <libxml/HTMLparser.h>等相关头文件编译错误问题
- [互联网面试笔试汇总C/C++-14] 判断一棵二叉树是否是二叉搜索树-微策略
- 国内著名IT公司(百度、搜狗、网易、新浪)2012校园招聘笔试、面试小结
- SQL server Profiler and excution plan usage for CPU usage high analysis
- android.database.StaleDataException: Attempted to access a cursor after it has been closed
- PowerHA 7.1 .1 新特征
- ubuntu下关闭独立显卡
- hibernate两表查询
- Linux下向oracle数据库倒入dmp包的方式
- phpcms v9 附件无法上传解决办法