当前位置: 首页 > article >正文

LeetCode:98. 验证二叉搜索树

目录

题目描述:

代码:

第一种:

第二种:

第三种:


题目描述:

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

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

  • 节点的左

    子树

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

示例 1:

输入:root = [2,1,3]
输出:true

示例 2:

输入:root = [5,1,4,null,null,3,6]
输出:false

代码:

第一种:

范围递归

 public boolean isValidBST(TreeNode root) {
        return isValid(root,Long.MIN_VALUE,Long.MAX_VALUE);
    }

    private boolean isValid(TreeNode root, long minValue, long maxValue) {
        if(root==null){
            return true;
        }
        if(root.val<=minValue||root.val>=maxValue){
            return false;
        }
        return isValid(root.left,minValue,root.val)&&isValid(root.right,root.val,maxValue);
    }

第二种:

中序递归

 long pre=Long.MIN_VALUE;
    public boolean isValidBST2(TreeNode root) {
        if(root==null){
            return true;
        }
        boolean a=isValidBST2(root.left);
        //此时a已经为false,但还是会继续往下进行下去的
        if(!a){
            return false;
        }
        if(pre>=root.val){
            return false;
        }
        pre=root.val;
        return isValidBST2(root.right);
    }

第三种:

中序非递归

 public boolean isValidBST1(TreeNode root) {
        TreeNode p = root;
        LinkedList<TreeNode> stack = new LinkedList<>();
        long prev =Long.MIN_VALUE;
        while (p != null || !stack.isEmpty()) {
            if(p!=null){
                stack.push(p);
                p = p.left;
            }else{
                TreeNode pop= stack.pop();
                if(prev>=pop.val){
                    return false;
                }
                prev = pop.val;
                p=pop.right;
            }
        }
        return true;
    }


http://www.kler.cn/a/405191.html

相关文章:

  • 2024年亚太地区数学建模大赛D题-探索量子加速人工智能的前沿领域
  • 揭秘AIGC下的数字时代:交互设计的隐秘力量与未来革命
  • SAP B1 登陆报错解决方案 - 系统架构目录服务器选择
  • Docker Registry(镜像仓库)详解
  • nacos镜像启动时候报Public Key Retrieval is not allowed
  • 前端—Cursor编辑器
  • 【Swift】类型标注、类型安全和类型推断
  • 【C++】友元成员
  • 给定一个数查找所在区间或者查找所有重叠区间的算法总结
  • Mac配置maven环境及在IDEA中配置Maven
  • @Autowired 和 @Resource思考(注入redisTemplate时发现一些奇怪的现象)
  • 商用密码产品认证名录说明
  • C++在实际项目中的应用第二节:C++与区块链
  • oracle初始化参数
  • Flutter:AnimatedBuilder自定义显示动画
  • mac-mini的时间机器,数据备份到alist 中的网盘
  • 山东春季高考-C语言-综合应用题
  • WPF里面的C1FlexGrid表格控件添加RadioButton单选
  • Hive离线数仓结构分析
  • 树莓派2装FreeBSD14.1 Raspberry Pi2 install FreeBSD14.1 00000121:error:0A000086:SSL
  • ✅✅✅【Vue.js】sd.js基于jQuery Ajax最新原生完整版for凯哥API版本
  • 深度学习中的正则化技术
  • C++中的组合模式
  • 「Mac玩转仓颉内测版23」基础篇3 - 深入理解整数类型
  • Ubuntu24.04解决向日葵安装libgconf-2-4依赖问题
  • 鸿蒙学习高效开发与测试-ArkUI 框架(2)