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

二验证二叉搜索树

力扣原题

给你一个二叉树的根节点 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. 如果当前节点为父节点的右子节点,则不得小于父节点值,左边界为父节点值
相关推荐
程序员_三木4 分钟前
Three.js入门-Raycaster鼠标拾取详解与应用
开发语言·javascript·计算机外设·webgl·three.js
ALISHENGYA19 分钟前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(switch语句)
数据结构·算法
chengooooooo21 分钟前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
jackiendsc28 分钟前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法
姚先生9738 分钟前
LeetCode 54. 螺旋矩阵 (C++实现)
c++·leetcode·矩阵
开心工作室_kaic2 小时前
springboot476基于vue篮球联盟管理系统(论文+源码)_kaic
前端·javascript·vue.js
游是水里的游2 小时前
【算法day20】回溯:子集与全排列问题
算法
川石教育2 小时前
Vue前端开发-缓存优化
前端·javascript·vue.js·缓存·前端框架·vue·数据缓存
搏博2 小时前
使用Vue创建前后端分离项目的过程(前端部分)
前端·javascript·vue.js
yoyobravery2 小时前
c语言大一期末复习
c语言·开发语言·算法