给定一个二叉树,判断它是否是合法的二叉查找树(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