# 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
def dfs(node, level, res):
if node.left is None and node.right is None:
res.append((node.val, level))
if node.left:
dfs(node.left, level + 1, res)
if node.right:
dfs(node.right, level + 1, res)
class Solution:
def deepestLeavesSum(self, root: TreeNode) -> int:
res = []
dfs(root, 0, res)
max_level = 0
for (v, level) in res:
max_level = max(max_level, level)
result = 0
for (v, level) in res:
if level == max_level:
result += v
return result