leetcode刷题日志-98.验证二叉搜索树

思路:根据二叉搜索树的性质,中序遍历满足升序。那么我们就可以使用中序dfs,并且记录每个节点的前一个节点的值,如果前一个节点值比后一个大,返回false。

复制代码
class Solution {
    Integer pre = null; //记录前序节点
    boolean isValid = true;
    public boolean isValidBST(TreeNode root) {
        dfs(root);
        return isValid;
    }
    public void dfs(TreeNode root)
    {
        if(root == null)
        return;
        else{
            dfs(root.left);
            if(pre == null){
                pre = root.val;
            }
            else if(pre >= root.val){ //如果前序大于当前,置为false
                isValid = false;
            }
            else{
                pre = root.val;
            }
            dfs(root.right);
        }
    }
}

递归一看就会一写就废,同学们多练习,多思考,多理解即可

相关推荐
伯远医学7 分钟前
CUT&RUN
java·服务器·网络·人工智能·python·算法·eclipse
圣保罗的大教堂16 分钟前
leetcode 2872. 可以被 K 整除连通块的最大数目 困难
leetcode
铅笔小新z19 分钟前
【C语言—数据结构】8种高效排序算法:从入门到实战
数据结构·算法·排序算法
AKDreamer_HeXY22 分钟前
AtCoder Beginner Contest 434 C-E 题解
c++·算法·前缀和·图论·差分·atcoder
roman_日积跬步-终至千里29 分钟前
【模式识别与机器学习(4)】主要算法与技术(中篇:概率统计与回归方法)之线性回归模型
算法·机器学习
小李小李快乐不已33 分钟前
图论理论基础(2)
java·开发语言·c++·算法·图论
点云SLAM34 分钟前
四元数 (Quaternion)微分-单位四元数 q(t) 的导数详细推导(10)
算法·计算机视觉·机器人·slam·imu·四元数·单位四元数求导
学学学无无止境35 分钟前
力扣-颠倒二进制位
leetcode
秋邱36 分钟前
2025 年突破性科技:大模型驱动的实时多模态数据流处理系统
人工智能·科技·算法·机器学习
sin_hielo37 分钟前
leetcode 2141
数据结构·算法·leetcode