欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 美景 > 力扣题/二叉树/二验证二叉搜索树

力扣题/二叉树/二验证二叉搜索树

2024/10/24 5:21:28 来源:https://blog.csdn.net/weixin_41895625/article/details/141191524  浏览:    关键词:力扣题/二叉树/二验证二叉搜索树

二验证二叉搜索树

力扣原题

给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。有效 二叉搜索树定义如下:节点的左子树 只包含 小于 当前节点的数。
节点的右子树 只包含 大于 当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。

示例 1:
在这里插入图片描述

输入:root = [2,1,3]
输出:true

示例 2:
在这里插入图片描述

输入:root = [5,1,4,null,null,3,6]
输出:false
解释:根节点的值是 5 ,但是右子节点的值是 4 。

/*** Definition for a binary tree node.* function TreeNode(val, left, right) {*     this.val = (val===undefined ? 0 : val)*     this.left = (left===undefined ? null : left)*     this.right = (right===undefined ? null : right)* }*/
/*** @param {TreeNode} root* @return {boolean}*/
var isValidBST = function(root) {return check(root, -Infinity, Infinity)
};function check(root, lower, upper) {if(!root) return trueconst val = root.val// 超过边界则验证失败if(val <= lower || val >= upper) return false// 左子树,值不得超过父节点值,范围区间(lower,val)     右子树,值不得小于父节点值,范围区间(val, upper)return check(root.left, lower, val) && check(root.right, val, upper)
}

解题思路

  1. 每个节点,都被其父节点约束,初始化边界为无穷小和无穷大
  2. 如果当前节点为父节点的左子节点,则不得大于父节点值,右边界为父节点值
  3. 如果当前节点为父节点的右子节点,则不得小于父节点值,左边界为父节点值

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com