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

三、官方解法

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

四、总结

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

相关推荐
元亓亓亓1 分钟前
LeetCode热题100--347. 前 K 个高频元素--中等
数据结构·算法·leetcode
Hello eveybody5 分钟前
冒泡、选择、插入排序简介(C++)
数据结构·算法·排序算法
CoderYanger6 分钟前
贪心算法:2.将数组和减半的最少操作次数
java·算法·leetcode·贪心算法·1024程序员节
Chen--Xing9 分钟前
LeetCode 49.字母异位词分组
c++·python·算法·leetcode·rust
长安er12 分钟前
LeetCode 235 & 236 最近公共祖先(LCA)解题总结
算法·leetcode·二叉树·递归·lca
im_AMBER16 分钟前
Leetcode 77 数组中的最大数对和 | 统计坏数对的数目
笔记·学习·算法·leetcode
代码游侠21 分钟前
学习笔记——Linux 进程管理笔记
linux·运维·笔记·学习·算法
lxmyzzs22 分钟前
【图像算法 - 38】工业巡检应用:基于 YOLO 与 OpenCV 的高精度管道缺陷检测系统实现
opencv·算法·yolo·管道检测
老鱼说AI22 分钟前
算法基础教学:哈希表
数据结构·算法·散列表
lxmyzzs24 分钟前
【图像算法 - 39】环保监测应用:基于 YOLO 与 OpenCV 的高精度水面垃圾检测系统实现
opencv·算法·yolo·水下垃圾检测