LeetCode111.二叉树的最小深度

111.二叉树的最小深度

描述

给定一个二叉树,找出其最小深度。

最小深度是从根节点到最近叶子节点的最短路径上的节点数量。

说明: 叶子节点是指没有子节点的节点。

示例

给定二叉树 [3,9,20,null,null,15,7],

    3
   / 
  9  20
    /  
   15   7

返回它的最小深度 2.

思路

乍一看跟上一题求最大深度一样,将 max 函数换成 min 函数试试。

提交后果然出错了,给了一个报错的例子 [1, 2] ,就是 root 只有一个右孩子或者左孩子的特殊情况。这种情况下,在没有孩子的那个字树中自认返回的是 0 ,故而最终结果为 0 。

应对这种情况,进行一下判断即可。

class Solution:
    def maxDepth(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        if not root:
            return 0
        elif root.left and root.right:
            return 1 + min(self.minDepth(root.left), self.minDepth(root.right))
        elif root.left:
            return 1 + self.minDepth(root.left)
        elif root.right:
            return 1 + self.minDepth(root.right)
        else:
            return 1

GitHub地址:https://github.com/protea-ban/LeetCode

原文地址:https://www.cnblogs.com/banshaohuan/p/9889609.html