LeetCode--98.验证二叉搜索树(二叉树)

98.验证二叉搜索树

题目描述

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

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

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

示例 1:

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

示例 2:

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

提示:

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

图解思路

中序遍历体现二叉搜索树的特征:

代码

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {

    public TreeNode pre = null;

    public boolean isValidBST(TreeNode root) {

        if(root == null) return false;

        // 遍历左子树
        boolean isLeftValid = true;
        if(root.left != null) isLeftValid = isValidBST(root.left);

        // 处理中间节点
        boolean valid = true;
        if(pre != null && root.val <= pre.val){
            valid = false;
        }
        pre = root;

        // 遍历右子树
        boolean isRightValid = true;
        if(root.right != null) isRightValid = isValidBST(root.right);

        return isLeftValid && isRightValid && valid;
    }
}
相关推荐
Misnearch1 小时前
3635. 最早完成陆地和水上游乐设施的时间II
leetcode·贪心·排序
Kurisu5752 小时前
深度拆解:从令牌桶到滑动窗口,高并发系统限流算法的数学本质与边界
java·网络·算法
哈泽尔都2 小时前
运动控制教学——5分钟学会力控算法(阻抗/导纳/力位混合)
c++·python·算法·决策树·贪心算法·机器人·gpu算力
WWW65262 小时前
代码随想录 打卡第四十七天
数据结构·算法·leetcode
cpp_25012 小时前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
smj2302_796826522 小时前
解决leetcode第3948题字典序最大的MEX数组
python·算法·leetcode
周末也要写八哥2 小时前
浅谈:C++中cpp 14 ~ cpp 17
开发语言·c++·算法
许彰午3 小时前
13_HashMap底层原理详解
算法·哈希算法
GIOTTO情3 小时前
基于 NLP 情感加权算法的智能舆情处置系统架构与落地实现
人工智能·算法·自然语言处理