当前位置:   article > 正文

LeetCode437题:路径总和III(python3)

LeetCode437题:路径总和III(python3)

437:路径总和III

整条路径和减去target和,如果存在这样的一个前缀节点,那count+1,遍历满足等式的,就可以加count

# 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) -> int:
        def dfs(node, cnts, cursum):
            if not node:
                return 0
            cursum += node.val #前缀和
            ans = cnts[cursum - targetSum] #前缀和-target
            cnts[cursum] += 1 #有就加count
            if node.left:
                ans += dfs(node.left, cnts, cursum)
            if node.right:
                ans += dfs(node.right, cnts, cursum)
            cnts[cursum] -= 1
            return ans
        return dfs(root, Counter([0]), 0)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/421043
推荐阅读
相关标签
  

闽ICP备14008679号