标签:
给定一个二叉树,判断它是否是合法的二叉查找树(BST)
一棵BST定义为:
节点的左子树中的值要严格小于该节点的值。
节点的右子树中的值要严格大于该节点的值。
左右子树也必须是二叉查找树。
因为二叉查找树的中序遍历是有序的。所以验证是否为二叉查找树,用中序遍历这个二叉树,如果前一个结点的值大于当前结点的值,则证明这个不是二叉树。
bool isValidBST(TreeNode *root) {
// write your code here
if(root == NULL)
return true;
stack<TreeNode*> stk;
TreeNode *pre = NULL;
while(root || !stk.empty())
{
if(root)
{
stk.push(root);
root = root->left;
}
else
{
root = stk.top();
stk.pop();
if(pre && (root->val <= pre->val))
return false;
pre = root;
root = root->right;
}
}
return true;
}
(95) Validate Binary Search Tree
http://www.lintcode.com/zh-cn/problem/validate-binary-search-tree/
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/zwhlxl/article/details/47304399