题目描述:
给定一个二叉树,找出其最大深度。
二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。
说明: 叶子节点是指没有子节点的节点。
题目求解:
递归求解:
# Definition for a binary tree node.
class TreeNode:
def __init__(self, val=0, left=None, right=None):
self.val = val
self.left = left
self.right = right
class Solution:
def maxDepth(self, root):
if not root:
return 0
else:
return max(self.maxDepth(root.left),self.maxDepth(root.right))+1
代码的关键是:
max(self.maxDepth(root.left),self.maxDepth(root.right))+1
它的含义是:
树的深度是他左右子树中较高的子树+1



