Medium
Given the root
of a binary tree, determine if it is a valid binary search tree (BST).
A valid BST is defined as follows:
Example 1:
Input: root = [2,1,3]
Output: true
Example 2:
Input: root = [5,1,4,null,null,3,6]
Output: false
Explanation: The root node’s value is 5 but its right child’s value is 4.
Constraints:
[1, 104]
.-231 <= Node.val <= 231 - 1
#include <stdio.h>
#include <stdbool.h>
#include <limits.h>
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* struct TreeNode *left;
* struct TreeNode *right;
* };
*/
// Helper function to check if the tree is a valid BST
bool solve(struct TreeNode* root, long left, long right) {
if (root == NULL) {
return true;
}
if (root->val <= left || root->val >= right) {
return false;
}
return solve(root->left, left, root->val) && solve(root->right, root->val, right);
}
// Main function to check if a tree is a valid BST
bool isValidBST(struct TreeNode* root) {
return solve(root, LONG_MIN, LONG_MAX);
}