- 标签:树、深度优先搜索、广度优先搜索、二叉树
- 难度:简单
描述:给定一个二叉树的根节点 root
。
要求:找出该二叉树的最大深度。
说明:
- 二叉树的深度:根节点到最远叶子节点的最长路径上的节点数。
- 叶子节点:没有子节点的节点。
示例:
- 示例 1:
输入:[3,9,20,null,null,15,7]
对应二叉树
3
/ \
9 20
/ \
15 7
输出:3
解释:该二叉树的最大深度为 3
根据递归三步走策略,写出对应的递归代码。
- 写出递推公式:
当前二叉树的最大深度 = max(当前二叉树左子树的最大深度, 当前二叉树右子树的最大深度) + 1
。- 即:先得到左右子树的高度,在计算当前节点的高度。
- 明确终止条件:当前二叉树为空。
- 翻译为递归代码:
- 定义递归函数:
maxDepth(self, root)
表示输入参数为二叉树的根节点root
,返回结果为该二叉树的最大深度。 - 书写递归主体:
return max(self.maxDepth(root.left) + self.maxDepth(root.right))
。 - 明确递归终止条件:
if not root: return 0
- 定义递归函数:
class Solution:
def maxDepth(self, root: Optional[TreeNode]) -> int:
if not root:
return 0
return max(self.maxDepth(root.left), self.maxDepth(root.right)) + 1
-
时间复杂度:$O(n)$,其中
$n$ 是二叉树的节点数目。 -
空间复杂度:$O(n)$。递归函数需要用到栈空间,栈空间取决于递归深度,最坏情况下递归深度为
$n$ ,所以空间复杂度为$O(n)$ 。