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;
    }
相关推荐
时光の尘17 分钟前
C语言菜鸟入门·关键字·void的用法
c语言·开发语言·c++·算法·c#·c·关键字
蚂蚁没问题s17 分钟前
图像处理 - 色彩空间转换
图像处理·人工智能·算法·机器学习·计算机视觉
戊子仲秋30 分钟前
【LeetCode】每日一题 2024_11_21 矩阵中的蛇(模拟)
算法·leetcode·矩阵
HP-Patience33 分钟前
【机器学习】- 模型复杂度vs模型误差
python·算法·机器学习
螺旋天光极锐斩空闪壹式!42 分钟前
第十三课 二维数组(2)方向数组
开发语言·c++·算法
peter80151 小时前
算法项目推荐
算法
小小白白蛆1 小时前
剑指offer JZ51 数组中的逆序对
数据结构·算法·排序算法
十五年专注C++开发1 小时前
C++不完整类型(Incomplete Type)的检测与避免
开发语言·c++·算法·设计模式
eternal19951 小时前
优化算法|基于Deep-Q-Network(DQN)的邻域搜索算法求解分布式柔性作业车间调度问题
分布式·算法
清流君3 小时前
【运动规划】移动机器人运动规划与轨迹优化全解析 | 经典算法总结
人工智能·笔记·算法·机器人·自动驾驶·运动规划