题目

请实现一个函数,检查一棵二叉树是否为二叉查找树。

给定树的根结点指针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;
}
};

最新文章

  1. Android系统自带APP分析——短信app
  2. uploadify firefox 401
  3. .net framework 4.6.2 下载
  4. VS2010常用快捷键
  5. Cisco中删除flash通过tftp服务器恢复
  6. CoreJavaE10V1P3.3 第3章 Java的基本编程结构-3.3 数据类型
  7. Got minus one from a read call异常
  8. Structured Streaming从Kafka 0.8中读取数据的问题
  9. Angular1.x使用小结
  10. WPF TreeView SelectedItemChanged called twice
  11. nginx:支持https
  12. jQuery找到GridView控件ItemTemplate模版内的控件
  13. java rpc
  14. SSH上传和下载文件
  15. 【BZOJ1210】[HNOI2004]邮递员 插头DP+高精度
  16. SVM计算过程,对偶形式,核函数
  17. python sort、sorted
  18. Effective STL 学习笔记: 多用 vector &amp; string
  19. 一:Shiro知识整理
  20. dedecms入侵拿webshell之方法总结

热门文章

  1. js动态插入标签代码(insertAdjacentHTML)
  2. consider increasing the maximum size of the cache.
  3. 本地Ubuntu16搭建Seafile
  4. pycharm解决Inconsistent indentation:mix of tabs and spaces
  5. 淘宝双十一页面(Flexible)demo
  6. 分享知识-快乐自己:SpringMVC 结合使用拦截器(判断是否用户是否已登陆)
  7. OpenCV——PS滤镜 漩涡 vertex
  8. bjwc Day3 &amp; 4 妈妈我这是来了个什么地方呀
  9. TTS API 使用
  10. HTML DOM nodeType 属性