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

三、官方解法

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

四、总结

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

相关推荐
xu_yule3 分钟前
数据结构(14)二叉树的模拟实现和便利代码
数据结构·算法
代码游侠15 分钟前
应用——文件I/O操作代码
linux·运维·c语言·笔记·学习·算法
发疯幼稚鬼19 分钟前
d-堆,左式堆及斜堆的简单介绍
算法
不会代码的小猴20 分钟前
C++的第十三天笔记
c++·笔记·算法
brave and determined23 分钟前
传感器学习(day04):红外感知:从经典热释电开关到智能时代的隐形慧眼
嵌入式硬件·算法·传感器·红外·嵌入式设计·红外矩阵·人体红外
南极星100523 分钟前
OPENCV(python)--初学之路(十六)SURF简介
python·opencv·算法
lxh011324 分钟前
合并区间题解
数据结构·算法·leetcode
yongui4783429 分钟前
基于MATLAB的轴承表面织构油膜参数计算程序
数据结构·算法·matlab
猎板PCB黄浩34 分钟前
多层电路板技术深度解析:高密度集成时代的核心支撑
网络·人工智能·算法
leoufung36 分钟前
LeetCode 39. Combination Sum 题解(回溯 / DFS)
算法·leetcode·深度优先