0113. Path Sum II
Last updated
Last updated
**Input:** root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
**Output:** [[5,4,11,2],[5,8,4,5]]
**Explanation:** There are two paths whose sum equals targetSum:
5 + 4 + 11 + 2 = 22
5 + 8 + 4 + 5 = 22**Input:** root = [1,2,3], targetSum = 5
**Output:** []**Input:** root = [1,2], targetSum = 0
**Output:** []/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public List<List<Integer>> pathSum(TreeNode root, int sum) {
List<List<Integer>> res = new ArrayList<List<Integer>>();
if (root == null) return res;
if (root.left == null && root.right == null && root.val == sum) {
List<Integer> tmp = new LinkedList<Integer>();
tmp.add(root.val);
res.add(tmp);
return res;
}
List<List<Integer>> left = pathSum(root.left, sum - root.val);
List<List<Integer>> right = pathSum(root.right, sum - root.val);
if (left.size() == 0 && right.size() == 0) {
return res;
}
if (left.size() != 0 && right.size() != 0) {
left.addAll(right);
res = left;
} else if (left.size() == 0) {
res = right;
} else if (right.size() == 0) {
res = left;
}
for (List<Integer> li : res) {
((LinkedList<Integer>)li).addFirst(root.val);
}
return res;
}
}class Solution {
public List<List<Integer>> pathSum(TreeNode root, int sum) {
List<List<Integer>> res = new ArrayList<List<Integer>>();
List<Integer> trackNote = new ArrayList<Integer>();
helper(res, trackNote, root, sum);
return res;
}
private void helper(List<List<Integer>> res, List<Integer> trackNote, TreeNode root, int sum) {
if (root == null) return;
trackNote.add(root.val);
if (root.left == null && root.right == null && root.val == sum) {
res.add(new ArrayList<Integer>(trackNote));
} else {
helper(res, trackNote, root.left, sum - root.val);
helper(res, trackNote, root.right, sum - root.val);
}
trackNote.remove(trackNote.size()-1);
return;
}
}