力扣 LeetCode 111. 二叉树的最小深度(Day7:二叉树)

解题思路:

用后序遍历

题目要求的最小深度为根节点到叶子节点的最小深度,注意是到根节点,所以如图所示假设(没有9这个节点)是需要返回3的,而不是1(根节点左子树为空的情况),于是需要加两层判断

其余部分可参考求最大深度的思路,有一定相似之处

java 复制代码
class Solution {
    public int minDepth(TreeNode root) {
        if (root == null) return 0;
        
        int leftDepth = minDepth(root.left);
        int rightDepth = minDepth(root.right);
        if (root.left == null && root.right != null) return 1 + rightDepth;
        if (root.left != null && root.right == null) return 1 + leftDepth;
        int res = 1 + Math.min(leftDepth, rightDepth);
        return res;
    }
}
相关推荐
csdn_aspnet18 小时前
C++ 算法 LeetCode 编号 70 - 爬楼梯
开发语言·c++·算法·leetcode
he___H18 小时前
leetcode100-合并区间
java·数据结构·算法
圣保罗的大教堂18 小时前
leetcode 2770. 达到末尾下标所需的最大跳跃次数 中等
leetcode
wuweijianlove18 小时前
算法性能优化中的数据流重构与依赖消解的技术6
算法
Agent手记18 小时前
智能财务对账Agent如何设计?2026金融大模型Agent架构设计与实战指引
人工智能·算法·ai·金融
Emerson_202618 小时前
stack,queue,list的区别和联系
数据结构·c++·list·queue·stack
计算机安禾19 小时前
【算法分析与设计】第5篇:最大子数组问题:分治与线性扫描的对比分析
算法
z2005093019 小时前
今日算法(组合问题)(回溯解法)
算法·深度优先
Shiy_19 小时前
用 TypeScript 验证三门问题:为什么换门胜率是 2/3?
算法·typescript
Yunzenn19 小时前
深度解析字节最新研究-Cola DLM 第 06 章:分块因果 DiT 先验 —— 在隐空间里做 Flow Matching
人工智能·算法·架构