Java算法_ 验证二叉搜索树(LeetCode_Hot100)

题目描述:

给你一个二叉树的根节点 ,判断其是否是一个有效的二叉搜索树。root 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。 节点的右子树只包含 大于 当前节点的数。 所有左子树和右子树自身必须也是二叉搜索树。
获得更多?算法思路:代码文档,算法解析的私得。

一个有效的二叉搜索树(BST)要求对于每个节点,其左子树中的所有节点值都要小于当前节点值,而其右子树中的所有节点值都要大于当前节点值。同时,还要确保每个子树自身也是一个有效的二叉搜索树。

基于这个思想,我们可以采用递归的方式来判断一个二叉树是否是有效的二叉搜索树。对于每个节点,我们可以限定一个上下界,保证其左子树的所有节点值都在这个上下界内,而右子树的所有节点值都在另一个上下界内。

具体步骤如下:

  1. 初始化递归函数,传入当前节点、左界限和右界限。
  2. 如果当前节点为空,直接返回 true。
  3. 如果当前节点值不在左界限和右界限范围内,返回 false。
  4. 对左子树递归调用,左界限不变,右界限变为当前节点值。
  5. 对右子树递归调用,左界限变为当前节点值,右界限不变。
  6. 如果左子树和右子树都返回 true,则说明当前节点及其子树是有效的二叉搜索树。
    这个过程递归地向下进行,最终判断整棵树是否是有效的二叉搜索树。
    运行效果

    完整代码
bash 复制代码
/**
 * 2 * @Author: LJJ
 * 3 * @Date: 2023/8/18 13:32
 * 4
 */
public class ValidateBST {
    static class TreeNode{
        int val;
        TreeNode left;
        TreeNode right;
        TreeNode(int val){
            this.val = val;
        }
    }

    // 主函数,判断给定二叉树是否为有效二叉搜索树
    public boolean isValidBST(TreeNode root){
        // 调用递归函数,初始值不限定上界和下界
        return isValidBST(root,null,null);
    }

    // 递归函数,判断以当前节点为根的子树是否为有效的二叉搜索树
    private boolean isValidBST(TreeNode node, Integer lower, Integer upper){

        // 递归终止条件,如果当前节点为空,说明子树是一个有效的二叉搜索树
        if (node == null){
            return true;
        }
        int val = node.val;

        // 检查当前结点的是否在合适的范围内
        if (lower != null && val <= lower){
            return false;
        }
        if (upper != null && val >= upper){
            return false;
        }

        // 递归判断左子树和右子树是否是有效的二叉搜索树
        // 对于左子树,当前节点的值成为上界;对于右子树,当前节点的值成为下界
        return isValidBST(node.left,lower,val) && isValidBST(node.right,val,upper);
    }

    public static void main(String[] args) {
        ValidateBST validateBST = new ValidateBST();

        // 创建示例二叉树
        TreeNode root = new TreeNode(5);
        root.left = new TreeNode(2);
        root.right = new TreeNode(7);
        root.left.left = new TreeNode(1);
        root.left.right = new TreeNode(3);
        root.right.left = new TreeNode(6);
        root.right.right = new TreeNode(8);

        // 调用验证函数并输出结果
        boolean isValid = validateBST.isValidBST(root);
        System.out.println("是否为二叉搜索树? " + isValid); // 输出 true
    }
}
相关推荐
penguin_bark1 分钟前
LCR 068. 搜索插入位置
算法·leetcode·职场和发展
一丝晨光5 分钟前
Java、PHP、ASP、JSP、Kotlin、.NET、Go
java·kotlin·go·php·.net·jsp·asp
罗曼蒂克在消亡9 分钟前
2.3MyBatis——插件机制
java·mybatis·源码学习
_GR20 分钟前
每日OJ题_牛客_牛牛冲钻五_模拟_C++_Java
java·数据结构·c++·算法·动态规划
ROBIN__dyc32 分钟前
表达式
算法
无限大.33 分钟前
c语言200例 067
java·c语言·开发语言
余炜yw35 分钟前
【Java序列化器】Java 中常用序列化器的探索与实践
java·开发语言
攸攸太上35 分钟前
JMeter学习
java·后端·学习·jmeter·微服务
无限大.36 分钟前
c语言实例
c语言·数据结构·算法
Kenny.志38 分钟前
2、Spring Boot 3.x 集成 Feign
java·spring boot·后端