LEETCODE 111. 二叉树的最小深度
题目描述
给定一个二叉树,找出其最小深度。
最小深度是从根节点到最近叶子节点的最短路径上的节点数量。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7],
3
/ \
9 20
/ \
15 7
返回它的最小深度 2.
代码实现
class Solution(object): def minDepth(self, root): """ :type root: TreeNode :rtype: int """ def recursion(root): if(not root): return 0 left = recursion(root.left) right = recursion(root.right) if(left==0 or right==0): return left+right+1 return min(left,right)+1 return recursion(root)
另一种实现方式
# Definition for a binary tree node. # class TreeNode(object): # def __init__(self, x): # self.val = x # self.left = None # self.right = None class Solution(object): def minDepth(self, root): """ :type root: TreeNode :rtype: int """ if not root: return 0 if not root.left and not root.right: return 1 elif not root.left: return self.minDepth(root.right) + 1 elif not root.right: return self.minDepth(root.left) + 1 else: return min(self.minDepth(root.left), self.minDepth(root.right))+10 次阅读