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

这篇具有很好参考价值的文章主要介绍了Java算法_ 验证二叉搜索树(LeetCode_Hot100)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目描述:
给你一个二叉树的根节点 ,判断其是否是一个有效的二叉搜索树。root 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。 节点的右子树只包含 大于 当前节点的数。 所有左子树和右子树自身必须也是二叉搜索树。

获得更多?算法思路:代码文档,算法解析的私得。
一个有效的二叉搜索树(BST)要求对于每个节点,其左子树中的所有节点值都要小于当前节点值,而其右子树中的所有节点值都要大于当前节点值。同时,还要确保每个子树自身也是一个有效的二叉搜索树。
基于这个思想,我们可以采用递归的方式来判断一个二叉树是否是有效的二叉搜索树。对于每个节点,我们可以限定一个上下界,保证其左子树的所有节点值都在这个上下界内,而右子树的所有节点值都在另一个上下界内。
具体步骤如下:

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

运行效果
Java算法_ 验证二叉搜索树(LeetCode_Hot100),java算法,算法,java,leetcode

完整代码文章来源地址https://www.toymoban.com/news/detail-662361.html

/**
 * 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
    }
}

到了这里,关于Java算法_ 验证二叉搜索树(LeetCode_Hot100)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构与算法之二叉树: Leetcode 98. 验证二叉搜索树 (Typescript版)

    验证二叉搜索树 https://leetcode.cn/problems/validate-binary-search-tree/ 描述 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。 节点的右子树只包含 大于 当前节点的数。 所有左子树和右子树自身

    2024年02月16日
    浏览(28)
  • 算法训练day20Leetcode654最大二叉树617合并二叉树700二叉树中的1搜索98验证二叉搜索树

    https://leetcode.cn/problems/maximum-binary-tree/description/ 中序遍历递归,找到最大值然后作为根节点 凡是构造二叉树的题目都用前序遍历 (中左右) 为先构造中间节点,然后递归构造左子树和右子树。 确定递归函数的参数和返回值 参数传入的是存放元素的数组,返回该数组构造的二

    2024年01月21日
    浏览(32)
  • 力扣HOT100 - 230. 二叉搜索树中第K小的元素

    解题思路:

    2024年04月25日
    浏览(26)
  • 【算法刷题day20】Leetcode:654. 最大二叉树、617.合并二叉树、700. 二叉搜索树中的搜索、98.验证二叉搜索树

    草稿图网站 java的Deque 题目: 654. 最大二叉树 解析: 代码随想录解析 解题思路 NLR的建树 代码 总结 暂无 题目: 617.合并二叉树 解析: 代码随想录解析 解题思路 如果都为root1, root2都为空,返回null;如果root1为空,root2不为空,返回root2;如果roo1不为空,root2为空,返回root

    2024年04月10日
    浏览(31)
  • 【算法Hot100系列】搜索插入位置

    💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学习,不断总结,共同进步,活到老学到老 导航 檀越剑指大厂系列:全面总

    2024年02月03日
    浏览(38)
  • 【算法Hot100系列】搜索旋转排序数组

    💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学习,不断总结,共同进步,活到老学到老 导航 檀越剑指大厂系列:全面总

    2024年01月21日
    浏览(45)
  • LeetCode刷题--- 验证二叉搜索树

    个人主页:元清加油_【C++】,【C语言】,【数据结构与算法】-CSDN博客 个人专栏:力扣递归算法题                    【C++】   前言:这个专栏主要讲述递归递归、搜索与回溯算法,所以下面题目主要也是这些算法做的   我讲述题目会把讲解部分分为3个部分: 1、题目解析

    2024年02月04日
    浏览(26)
  • LeetCode 98. 验证二叉搜索树

    ​ 给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。 节点的右子树只包含 大于 当前节点的数。 所有左子树和右子树自身必须也是二叉搜索树。 示例 1: ​​​​ 输入:root = [2,1,

    2024年02月09日
    浏览(24)
  • Leetcode98. 验证二叉搜索树

    力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 给你一个二叉树的根节点  root  ,判断其是否是一个有效的二叉搜索树。 有效  二叉搜索树定义如下: 节点的左子树只包含  小于  当前节点的数。 节点的右子树只包含  大于  当前节点的数。 所有左子树和右子树自身

    2024年02月11日
    浏览(32)
  • java数据结构与算法刷题-----LeetCode96. 不同的二叉搜索树

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 很多人觉得动态规划很难,但它就是固定套路而已。其实动态规划只不过是将多余的步骤,提前放到dp数组中(就是一个数组,只

    2024年01月21日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包