验证二叉搜索树

题目

给定一个二叉树,判断其是否是一个有效的二叉搜索树。
假设一个二叉搜索树具有如下特征:
节点的左子树只包含小于当前节点的数。
节点的右子树只包含大于当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。
示例1:
输入:
2
/
1 3
输出: true
示例2:
输入:
5
/
1 4
? /
? 3 6
输出: false
解释: 输入为: [5,1,4,null,null,3,6]。
根节点的值为 5 ,但是其右子节点值为 4 。‘

分析

	1.首先需要确认被验证的事物特点。二叉搜索树的特点是左子树所包含节点小于其根节点,右子树则大于。
	2.上面的解法我们相当于初始化两个极值,然后在递归中将极值替换成节点值,之所以用long是因为可以包含int
	  的边界值。

附注:
1.其实可以发现二叉搜索树的中序遍历是有序的,所以我们可以将所有元素压入数组,然后判定这个数组是否是
有序的即可。这个中序遍历是有序的点,是需要仔细观察题目所给信息
2.一般来说二叉树,可以优先想到递归。

#include<algorithm>

using namespace std;

struct TreeNode{
	int val;
	TreeNode* right;
	TreeNode* left;
	TreeNode() :val(0), right(nullptr), left(nullptr){}
};

class MyClass{
public:
	bool isValidBST(TreeNode* root) {
		if (!root){
			return true;
		}
		return isValidBST(root, LONG_MIN, LONG_MAX);
	}

	bool isValidBST(TreeNode* root, long left, long right){
		if (!root){
			return true;
		}

		if (root->val <= left || root->val >= right){
			return false;
		}

		return isValidBST(root->left, left, root->val) && isValidBST(root->right, root->val, right);
	}
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值