力扣 验证二叉搜索树
题目描述
给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。
有效 二叉搜索树定义如下:
节点的左子树只包含 小于 当前节点的数。
节点的右子树只包含 大于 当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。
示例 1:
输入:root = [2,1,3]
输出:true
示例 2:
输入:root = [5,1,4,null,null,3,6]
输出:false
解释:根节点的值是 5 ,但是右子节点的值是 4 。
思路分析
此题目需要保证任何节点的左子树的最右边的节点小于该节点,任何节点的右子树的最左边的节点大于该节点。
通过分析我们发现此题实际上是要求出中序遍历二叉树的序列,然后判断该序列是否为递增序列即可。
代码如下:
class Solution {
public:
bool isValidBST(TreeNode* root) {
stack<TreeNode*> s;
vector<int>res;
TreeNode* p=root;
while(p!=nullptr||!s.empty()){
while(p!=nullptr){
s.push(p);
p=p->left;
}
if(!s.empty()){
p=s.top();
res.push_back(p->val);
s.pop();
p=p->right;
}
}
for(int i=0;i<res.size()-1;i++){
if(res[i]>=res[i+1])return false;
}
return true;
}
};