力扣98 验证二叉搜索树 java实现

  1. 验证二叉搜索树

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

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

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

示例 1:

复制代码
输入:root = [2,1,3]
输出:true

示例 2:

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

提示:

  • 树中节点数目范围在[1, 104]
  • -231 <= Node.val <= 231 - 1

二叉搜索树的中序遍历(左 中 右)正好是按从小到大排的,所以用中序遍历来解决该题较容易。

用递归来只需要记录前一个元素,然后按左 中 右递归即可。

java 复制代码
public class hot {
    public static void main(String[] args) {  // 测试用
        TreeNode treeNode1 = new TreeNode(2);
        treeNode1.left = new TreeNode(1);
        treeNode1.right = new TreeNode(3);
        hot hot = new hot();
        System.out.println(hot.isValidBST(treeNode1));
    }

    long pre = Long.MIN_VALUE;
    public boolean isValidBST(TreeNode root) {
        if(root.left == null && root.right == null){
            return true;
        }
        boolean res = dfs(root);
        return res;
    }

    public  boolean dfs(TreeNode root){
        if (root == null){
            return true;
        }
        if (!dfs(root.left)){ // 左
            return false;
        }
        if (root.val <= pre){ // 中
            return false;
        }
        pre = root.val;      // 记录前一个值
        if (!dfs(root.right)){ // 右
            return false;
        }
        return true;
    }
}

以上为记录分享用,代码较差请见谅

相关推荐
身如柳絮随风扬8 小时前
Java中的CAS机制详解
java·开发语言
-dzk-9 小时前
【代码随想录】LC 59.螺旋矩阵 II
c++·线性代数·算法·矩阵·模拟
风筝在晴天搁浅9 小时前
hot100 78.子集
java·算法
Jasmine_llq9 小时前
《P4587 [FJOI2016] 神秘数》
算法·倍增思想·稀疏表(st 表)·前缀和数组(解决静态区间和查询·st表核心实现高效预处理和查询·预处理优化(提前计算所需信息·快速io提升大规模数据读写效率
超级大只老咪9 小时前
快速进制转换
笔记·算法
m0_7066532310 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你9110 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_4232339010 小时前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder12310 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_7155753410 小时前
分布式任务调度系统
开发语言·c++·算法