【LeetCode算法】第111题:二叉树的最小深度

目录

一、题目描述

二、初次解答

三、官方解法

四、总结


一、题目描述

二、初次解答

1. 思路: 二叉树的先序遍历。求出左子树的最小高度,求出右子树的最小高度,最终返回左子树和右子树的最小高度+1。**关键:**若左子树的高度为0,则返回右子树的最小高度+1;若右子树的高度为0,则返回左子树的最小高度+1;若左右子树都不为空,则返回左子树与右子树的最小高度。

2. 代码:

cpp 复制代码
int minDepth(struct TreeNode* root) {
    //根节点为空
    if(!root)
        return 0;
    //叶子节点
    if(!(root->left) && !(root->right))
        return 1;
    int minLeft=minDepth(root->left);   //递归左子树
    int minRight=minDepth(root->right); //递归右子树
    if(minLeft==0) return minRight+1;   //左子树无节点
    if(minRight==0) return minLeft+1;   //右子树无节点
    return minLeft>minRight?minRight+1:minLeft+1;   //左右子树的最小高度
}

**3. 优点:**仅遍历一遍二叉树,时间复杂度为O(n)。

**4. 缺点:**采用了递归,空间复杂度为O(H),H为树的高度。

三、官方解法

官方解法一的深度优先遍历与上述解法类似。解法二的广度优先遍历需要手动维护队列且空间复杂度不如解法一,因此不展开说明。

四、总结

求二叉树的最小深度:使用二叉树的先序遍历,递归求出左子树和右子树的最小深度,并考虑到左子树和右子树为空的情况。

相关推荐
0 0 02 分钟前
洛谷P4427 [BJOI2018] 求和 【考点】:树上前缀和
开发语言·c++·算法·前缀和
阿拉斯攀登8 分钟前
第 2 篇 小白前置知识急救包!RK 安卓驱动开发必备知识点,一篇补全
c语言·嵌入式·rk3568·安卓驱动
佩奇大王9 分钟前
P593 既约分数
java·开发语言·算法
云泽80814 分钟前
蓝桥杯算法精讲:贪心算法之推公式例题深度剖析
算法·贪心算法·蓝桥杯
客卿12335 分钟前
力扣--组合,子集--回溯法的再探索--总结回溯法
java·算法·leetcode
zh路西法36 分钟前
【C语言简明教程提纲】(四):结构体与文件定义和操作
android·c语言·redis
_日拱一卒37 分钟前
LeetCode(力扣):环形链表
算法·leetcode·链表
做怪小疯子40 分钟前
Leetcode刷题——链表就地反转
算法·leetcode·链表
仟濹1 小时前
【算法打卡day22(2026-03-14 周六)今日算法or技巧:双指针 & 链表】9个题
数据结构·算法·链表·双指针
RechoYit1 小时前
数学建模——评价与决策类模型
python·算法·数学建模·数据分析