【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为树的高度。

三、官方解法

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

四、总结

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

相关推荐
Fang fan几秒前
Java集合
java·开发语言·算法
AI成长日志5 分钟前
【笔面试算法学习专栏】链表操作专题:反转、环形检测与合并
学习·算法·面试
njidf11 分钟前
C++与量子计算模拟
开发语言·c++·算法
阿Y加油吧14 分钟前
面试硬核双杀!合并 K 个升序链表 + LRU 缓存|力扣高频手撕原题全解
数据结构·leetcode·链表
老鼠只爱大米15 分钟前
LeetCode经典算法面试题 #70:爬楼梯(朴素递归、记忆化递归、动态规划等六种实现方案详解)
算法·leetcode·动态规划·递归·斐波那契·矩阵快速幂·爬楼梯
我材不敲代码22 分钟前
OpenCV 光流估计实战:Lucas-Kanade 算法实现运动目标跟踪
opencv·算法·目标跟踪
是翔仔呐24 分钟前
第10章 串口通信USART全解:轮询/中断/DMA三种收发模式与上位机通信实战
c语言·开发语言·stm32·单片机·嵌入式硬件·学习·gitee
计算机安禾37 分钟前
【数据结构与算法】第12篇:栈(二):链式栈与括号匹配问题
c语言·数据结构·c++·学习·算法·visual studio code·visual studio
散峰而望1 小时前
【数据结构】单调栈与单调队列深度解析:从模板到实战,一网打尽
开发语言·数据结构·c++·后端·算法·github·推荐算法
qwehjk20081 小时前
内存泄漏自动检测系统
开发语言·c++·算法