029-力扣刷题-104--二叉树的最大深度

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

二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。

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

示例: 给定二叉树 [3,9,20,null,null,15,7], image.png

 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