Validate Binary Search Tree
Given a binary tree, determine if it is a valid binary search tree (BST).
Assume a BST is defined as follows:
- The left subtree of a node contains only nodes with keys less than the node's key.
- The right subtree of a node contains only nodes with keys greater than the node's key.
- Both the left and right subtrees must also be binary search trees.
这题需要判断是不是一个正确的二叉搜索树,比较简单地一道题。
我们通过递归整棵树来解决,代码如下:
class Solution {
public:
    bool isValidBST(TreeNode *root) {
        return valid(root, numeric_limits<int>::min(), numeric_limits<int>::max());
    }
    bool valid(TreeNode* node, int minVal, int maxVal) {
        if(!node) {
            return true;
        }
        if(node->val <= minVal || node->val >= maxVal) {
            return false;
        }
        return valid(node->left, minVal, node->val) &&
        valid(node->right, node->val, maxVal);
    }
};