CC22:检查是否为BST
2024-08-30 04:16:28
题目
请实现一个函数,检查一棵二叉树是否为二叉查找树。
给定树的根结点指针TreeNode* root,请返回一个bool,代表该树是否为二叉查找树。
解法
二叉排序树有个特点是,结点通过中序遍历出来的顺序一定是从小到大的,利用这个特点我们就可以解此题。将中序遍历后的数据判断一下就OK:
/*
struct TreeNode {
int val;
struct TreeNode *left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};*/
class Checker {
public:
void inorder(TreeNode* root)
{
if(root==NULL)
return ;
inorder(root->left);
temp.push_back(root->val);
inorder(root->right);
}
bool checkBST(TreeNode* root) {
// write code Here
if(root==NULL)
return true;
inorder(root);
for(int i=0;i<temp.size()-1;i++)
{
if(temp[i]>temp[i+1])
return false;
}
return true;
}
private:
vector<int> temp;
};
还可以在中序遍历的同时,比较大小,每次记录下上次遍历过的元素的值,如果当前元素的值大于上次遍历元素的值,则接着遍历,否则返回false,因为这个记录是一个址传递,所以需要用到引用形参进行传递。见代码:
class Checker {
public:
bool checkBST(TreeNode* root) {
// write code here
int min = INT_MIN;
return inOrderCompare(root, min);
}
bool inOrderCompare(TreeNode* root, int &last)
{
if (root == NULL)
return true;
if (!inOrderCompare(root->left, last))
return false;
if (root->val < last)
return false;
last = root->val;
if (!inOrderCompare(root->right, last))
return false;
return true;
}
};
最新文章
- Android系统自带APP分析——短信app
- uploadify firefox 401
- .net framework 4.6.2 下载
- VS2010常用快捷键
- Cisco中删除flash通过tftp服务器恢复
- CoreJavaE10V1P3.3 第3章 Java的基本编程结构-3.3 数据类型
- Got minus one from a read call异常
- Structured Streaming从Kafka 0.8中读取数据的问题
- Angular1.x使用小结
- WPF TreeView SelectedItemChanged called twice
- nginx:支持https
- jQuery找到GridView控件ItemTemplate模版内的控件
- java rpc
- SSH上传和下载文件
- 【BZOJ1210】[HNOI2004]邮递员 插头DP+高精度
- SVM计算过程,对偶形式,核函数
- python sort、sorted
- Effective STL 学习笔记: 多用 vector &; string
- 一:Shiro知识整理
- dedecms入侵拿webshell之方法总结
热门文章
- js动态插入标签代码(insertAdjacentHTML)
- consider increasing the maximum size of the cache.
- 本地Ubuntu16搭建Seafile
- pycharm解决Inconsistent indentation:mix of tabs and spaces
- 淘宝双十一页面(Flexible)demo
- 分享知识-快乐自己:SpringMVC 结合使用拦截器(判断是否用户是否已登陆)
- OpenCV——PS滤镜 漩涡 vertex
- bjwc Day3 &; 4 妈妈我这是来了个什么地方呀
- TTS API 使用
- HTML DOM nodeType 属性