给定一个二叉树 root ,返回其最大深度。
二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。
示例 1:
输入:root = [3,9,20,null,null,15,7]
输出:3
示例 2:
输入:root = [1,null,2]
输出:2
提示:
树中节点的数量在 [0, 104] 区间内。
-100 <= Node.val <= 100
# 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: Optional[TreeNode]) -> int:
if not root:
return 0
sub_left=self.maxDepth(root.left)
sub_right=self.maxDepth(root.right)
return 1+max(sub_left,sub_right)
'''
self.depth=0
self.max_dep=0
self.m_depth(root)
return self.max_dep
def m_depth(self,root):
if not root:
return 0
self.depth+=1
self.max_dep=max(self.depth,self.max_dep)
self.m_depth(root.left)
self.m_depth(root.right)
self.depth-=1
'''