能用Java写吗
时间: 2023-07-01 19:11:54 浏览: 127
当然可以,以下是Java版本的实现:
```java
class Solution {
public int pathSum(TreeNode root, int targetSum) {
List<Integer> sumList = new ArrayList<>();
sumList.add(0);
return dfs(root, sumList, targetSum);
}
public int dfs(TreeNode node, List<Integer> sumList, int targetSum) {
if (node == null) {
return 0;
}
int count = 0;
int curSum = sumList.get(sumList.size() - 1) + node.val;
for (int i = 0; i < sumList.size(); i++) {
if (curSum - sumList.get(i) == targetSum) {
count++;
}
}
sumList.add(curSum);
count += dfs(node.left, sumList, targetSum);
count += dfs(node.right, sumList, targetSum);
sumList.remove(sumList.size() - 1);
return count;
}
}
```
希望对你有帮助!
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="application/x-rar"