leetcode98-验证二叉搜索树

leetcode 98

这里要验证二叉搜索树的关键是知道二叉搜索树的特性:

  • 节点的左子树只包含小于当前节点的值
  • 节点的右子树只包含大于当前节点的值
  • 所有左子树和右子树自身必须也是二叉搜索树
    根据这些特性,可以知道,如果使用中序遍历:左中右,得到的是从小到大排序的,那说明是二叉搜索树

我们可以默认先把这个二叉树当成是二叉搜索树,所以初始化设置result = true

由于二叉搜索树中序遍历后的结果是递增的,我们初始化maxValue = -Infinity,用于存储上次的节点值,下一个节点值就一定是大于maxValue的,否则就不是二叉搜索树 - > 修改result = false

如果下一个值更大,那么更新maxValue

js 复制代码
var isValidBST = function(root) {
   let result = true;
   let maxValue = -Infinity;
   const deep = (root) => {
       if(!root) return
       result && root.left && deep(root.left)
       if(maxValue >= root.val){
           result = false;
       }else{
       	maxValue = root.val;
       }
       result && root.right && deep(root.right)
   }
   deep(root)
   return result;
};
相关推荐
如意猴4 分钟前
实现链式结构二叉树--递归中的暴力美学(第13讲)
数据结构
初夏睡觉5 分钟前
P1048 [NOIP 2005 普及组] 采药
数据结构·c++·算法
小欣加油6 分钟前
leetcode 1513 仅含1的子串数
c++·算法·leetcode·职场和发展
树在风中摇曳30 分钟前
【C语言预处理器全解析】宏、条件编译、字符串化、拼接
c语言·算法
CodeWizard~1 小时前
P7149 [USACO20DEC] Rectangular Pasture S题解
算法
fashion 道格1 小时前
用 C 语言破解汉诺塔难题:递归思想的实战演练
c语言·算法
李玮豪Jimmy1 小时前
Day18:二叉树part8(669.修剪二叉搜索树、108.将有序数组转换为二叉搜索树、538.把二叉搜索树转换为累加树)
java·服务器·算法
Zero不爱吃饭1 小时前
环形链表(C)
数据结构·链表
xiaoye-duck1 小时前
数据结构之二叉树-链式结构(下)
数据结构·算法
Kt&Rs1 小时前
11.13 LeetCode 题目汇总与解题思路
数据结构·算法