leetcode_113 路径总和 II

355 阅读1分钟

要求

给你二叉树的根节点 root 和一个整数目标和 targetSum ,找出所有 从根节点到叶子节点 路径总和等于给定目标和的路径。

叶子节点 是指没有子节点的节点。

示例 1:

image.png

输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:[[5,4,11,2],[5,8,4,5]]

示例 2:

image.png

输入:root = [1,2,3], targetSum = 5
输出:[]

示例 3:

输入:root = [1,2], targetSum = 0
输出:[]

提示:

  • 树中节点总数在范围 [0, 5000] 内
  • -1000 <= Node.val <= 1000
  • -1000 <= targetSum <= 1000

核心代码

# 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 pathSum(self, root: Optional[TreeNode], targetSum: int) -> List[List[int]]:
        if not root:
            return []
        return self.find_sum(root,targetSum,[])
    
    def find_sum(self,tree,s,path):
        ans = []
        if self.is_leaf(tree):
            if tree.val == s:
                ans.append([*path,tree.val])
        else:
            if tree.left:
                ans.extend(self.find_sum(tree.left,s-tree.val,[*path,tree.val]))
            if tree.right:
                ans.extend(self.find_sum(tree.right,s-tree.val,[*path,tree.val]))
        return ans
    
    def is_leaf(self,node):
        return not node.left and not node.right

image.png

解题思路:和前面路径总和的解题思路一样,只不过是这个题增加了一个目标值,我们从根节点向下遍历到叶子节点,一路标记数值,然后和目标值进行比对,看是否一致,一致就加入到输出结果中。