029-力扣刷题-104--二叉树的最大深度
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
说明: 叶子节点是指没有子节点的节点。
示例:
给定二叉树 [3,9,20,null,null,15,7],
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | # 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 maxDepth(self, root): """ :type root: TreeNode :rtype: int """ if root is None: #如果root这个节点对象是空的就返回空的lieb return 0 else: #使用的就是递归算法,每一次返回都是toot节点的路径最长的子树,这样就可以一直递归到叶子节点,然后这里需要注意的是这个加1因为最后的叶子结点返回的是0但是本身也是包含了一层的,所以要加1 return max(self.maxDepth(root.left),self.maxDepth(root.right))+1 |