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

二验证二叉搜索树

力扣原题

复制代码
给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

有效 二叉搜索树定义如下:

节点的左子树 只包含 小于 当前节点的数。
节点的右子树 只包含 大于 当前节点的数。
所有左子树和右子树自身必须也是二叉搜索树。

示例 1:

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

输出:true

示例 2:

输入:root = [5,1,4,null,null,3,6]

输出:false

解释:根节点的值是 5 ,但是右子节点的值是 4 。

javascript 复制代码
/**
 * 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 true
    const 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. 如果当前节点为父节点的右子节点,则不得小于父节点值,左边界为父节点值
相关推荐
Carlos_sam29 分钟前
Opnelayers:ol-wind之Field 类属性和方法详解
前端·javascript
小毛驴85040 分钟前
创建 Vue 项目的 4 种主流方式
前端·javascript·vue.js
go54631584651 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae1 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法
大锦终1 小时前
【算法】前缀和经典例题
算法·leetcode
想变成树袋熊2 小时前
【自用】NLP算法面经(6)
人工智能·算法·自然语言处理
cccc来财2 小时前
Java实现大根堆与小根堆详解
数据结构·算法·leetcode
你这个年龄怎么睡得着的2 小时前
Babel AST 魔法:Vite 插件如何让你的 try...catch 不再“裸奔”?
前端·javascript·vite
Dream耀3 小时前
提升React移动端开发效率:Vant组件库
前端·javascript·前端框架
Coovally AI模型快速验证3 小时前
数据集分享 | 智慧农业实战数据集精选
人工智能·算法·目标检测·机器学习·计算机视觉·目标跟踪·无人机