299 字
1 分钟
LeetCode-437.路径总和 III

二叉树#

437. 路径总和 III

给定一个二叉树的根节点 root ,和一个整数 targetSum ,求该二叉树里节点值之和等于 targetSum路径 的数目。

路径 不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点)。


示例 1:

img
输入:root = [10,5,-3,3,2,null,11,3,-2,null,1], targetSum = 8
输出:3
解释:和等于 8 的路径有 3 条,如图所示。

示例 2:

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

递归的解法

思路:这题其实看过 113. 路径总和 II112. 路径总和 的题目后,比较一下就可以发现 本题的答案就是子节点的递归 + 根节点的路径数目,由此写出两个递归即可

/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func pathSum(root *TreeNode, targetSum int) int {
if root == nil {
return 0
}
res := rootsum(root, targetSum)
res += pathSum(root.Left, targetSum)
res += pathSum(root.Right, targetSum)
return res
}
func rootsum(node *TreeNode, targetSum int) int {
if node == nil {
return 0
}
count := 0
if node.Val == targetSum {
count++
}
count += rootsum(node.Left, targetSum-node.Val)
count += rootsum(node.Right, targetSum-node.Val)
return count
}
LeetCode-437.路径总和 III
https://sheep44044.github.io/posts/算法/二叉树/leetcode-437路径总和-iii/
作者
sheep44044
发布于
2026-03-18
许可协议
CC BY-NC-SA 4.0