题目:
给定一个二叉树,判断其是否是一个有效的二叉搜索树。
假设一个二叉搜索树具有如下特征:
节点的左子树只包含小于当前节点的数。
节点的右子树只包含大于当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。
示例 1:
输入:
2
/ \
1 3
输出: true
示例 2:
输入:
5
/ \
1 4
/ \
3 6
输出: false
解释: 输入为: [5,1,4,null,null,3,6]。
根节点的值为 5 ,但是其右子节点值为 4 。
题目分析
- 要求:
验证一棵二叉树是否为二叉搜索树
分析
对于某结点
判断其左子树的结点是否小于当前结点
判断其右子树的结点是否大于当前结点
解题思路
变量 | 作用 |
---|---|
isValidBST(TreeNode*root, long mn, long mx) | 判断一棵二叉树是否为二叉搜索树(root为根结点 mn为左子树的最大上限 mx为右子树的最小下限) |
过程
root初始化为根结点,mn初始化为long型最小值,mx初始化为long型最大值
- 如果左子树的值大于根结点的值或右节点的值小于根结点的值 ==> return false
- 递归判断左子树和右子树是否为二叉搜索树
代码如下
class Solution {
public:
bool isValidBST(TreeNode* root) {
return isValidBST(root,LONG_MIN,LONG_MAX);
}
bool isValidBST(TreeNode*root, long mn, long mx) {
if(!root) return true;
if(root->val <= mn || root->val >=mx) return false;
return isValidBST(root->left, mn, root->val) && isValidBST(root->right, root->val,mx);//判断左右子树是否为二叉树
}
};