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

三、官方解法

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

四、总结

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

相关推荐
无限进步_14 小时前
扫雷游戏的设计与实现:扫雷游戏3.0
c语言·开发语言·c++·后端·算法·游戏·游戏程序
qq_4335545414 小时前
C++ 完全背包
开发语言·c++·算法
lingran__14 小时前
算法沉淀第二天(Catching the Krug)
c++·算法
Yupureki14 小时前
从零开始的C++学习生活 8:list的入门使用
c语言·c++·学习·visual studio
im_AMBER15 小时前
杂记 15
java·开发语言·算法
爱coding的橙子15 小时前
每日算法刷题Day70:10.13:leetcode 二叉树10道题,用时2h
算法·leetcode·深度优先
ghie909015 小时前
基于MATLAB的遗传算法优化支持向量机实现
算法·支持向量机·matlab
朝新_16 小时前
【优选算法】第一弹——双指针(上)
算法
艾莉丝努力练剑16 小时前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
kyle~17 小时前
计算机系统---CPU的进程与线程处理
linux·服务器·c语言·c++·操作系统·计算机系统