0104. 二叉树的最大深度
题目地址(104. 二叉树的最大深度)
https://leetcode-cn.com/problems/maximum-depth-of-binary-tree/description/
题目描述
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
返回它的最大深度 3 。前置知识
公司
阿里
腾讯
百度
字节
apple
linkedin
uber
yahoo
思路
由于树是一种递归的数据结构,因此用递归去解决的时候往往非常容易,这道题恰巧也是如此,
用递归实现的代码如下:
如果使用迭代呢? 我们首先应该想到的是树的各种遍历,由于我们求的是深度,因此 使用层次遍历(BFS)是非常合适的。 我们只需要记录有多少层即可。相关思路请查看binary-tree-traversal
关键点解析
队列
队列中用 Null(一个特殊元素)来划分每层,或者在对每层进行迭代之前保存当前队列元素的个数(即当前层所含元素个数)
树的基本操作- 遍历 - 层次遍历(BFS)
代码
语言支持:JS,C++,Java,Python, Go, PHP
JS Code:
C++ Code:
Java Code:
Python Code:
Go Code:
PHP Code:
复杂度分析
时间复杂度:$O(N)$
空间复杂度:$O(N)$
相关题目
大家对此有何看法,欢迎给我留言,我有时间都会一一查看回答。更多算法套路可以访问我的 LeetCode 题解仓库:https://github.com/azl397985856/leetcode 。 目前已经 37K star 啦。 大家也可以关注我的公众号《力扣加加》带你啃下算法这块硬骨头。

最后更新于
这有帮助吗?