力扣- 统计二叉树中好节点的数目

思路分析

代码实现

java 复制代码
public int goodNodes(TreeNode root) {
    int goodNodesNum = dfs(root, Integer.MIN_VALUE);
    return count;
}

int count = 0;
public int dfs(TreeNode root, int pathMaxVal){
    // 递归出口
    if (root == null) {
        return 0;
    }
    if (root.val >= pathMaxVal) {
        count++;
        pathMaxVal = root.val;
    }


    int leftGoodNodes = dfs(root.left, pathMaxVal);
    int rightGoodNodes = dfs(root.right, pathMaxVal);
    return leftGoodNodes + rightGoodNodes;
}

代码优化

用全局变量 count 统计好节点数,逻辑上是可行的(因为递归过程中会共享这个变量),但全局变量在多线程场景下有线程安全问题,

java 复制代码
public int goodNodes(TreeNode root) {
    int count = dfs2(root, Integer.MIN_VALUE);
    return count;
}

public int dfs2(TreeNode root, int pathMaxVal){
    // 递归出口
    if (root == null) {
        return 0;
    }
    // 判断当前节点是否是号节点
    int current = root.val >= pathMaxVal ? 1 : 0;
    // 更新最大值
    pathMaxVal = Math.max(pathMaxVal, root.val);
    int leftGoodsNodes = dfs2(root.left, pathMaxVal);
    int rightGoodsNodes = dfs2(root.right, pathMaxVal);
    return current + leftGoodsNodes + rightGoodsNodes;
}

复杂度分析

  • 时间复杂度:固定为 O (n),因为必须遍历所有节点才能统计好节点,无法优化;
  • 空间复杂度:取决于树的高度,最优 O (logn)(平衡树),最坏 O (n)(单链树);
相关推荐
We་ct1 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮6 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说6 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove6 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
小程故事多_807 小时前
[大模型面试系列] 多轮对话 Agent 设计实战(含窗口优化 + 工具调用精髓)
人工智能·面试·职场和发展
leoufung7 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了7 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL7 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰7 小时前
C++ 排列组合完整指南
开发语言·c++·算法