参考博文
List调用add()方法为空解释(qq_34250494 的回答)
在做LeetCode 39. Combination Sum 时使用到了递归,在合适的条件下将本次结果添加到List<List> result 中。
class Solution {
public List<List<Integer>> combinationSum(int[] candidates, int target) {
Arrays.sort(candidates);
List<List<Integer>> result = new ArrayList();
getResult(result, new ArrayList<Integer>(), candidates, target, 0);
return result;
}
private void getResult(List<List<Integer>> result, List<Integer> arrayList, int[] candidates,
int target, int start) {
// TODO Auto-generated method stub
if(target > 0) {
for(int i = start; i < candidates.length;i ++) {
if(target >= candidates[i]) {
arrayList.add(candidates[i]);
getResult(result, arrayList, candidates, target - candidates[i], i);
arrayList.remove(arrayList.size() - 1);
}
}
}else if(target == 0) {
result.add(new ArrayList<Integer>(arrayList));
}
}
}
这里遇到了一个问题:
如果在getResult()方法最后这样添arayList,返回结果为空
但是如果使用result.add(new ArrayList(list)) 这样可以返回正确结果。
使用这段代码解释比较好
ArrayList<Integer> list = new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
List<List<Integer>> res = new ArrayList<>();
System.out.println(res);
res.add(list);
list.add(50);
res.add(list);
System.out.println(res+"发现两个元素竟然一样");
res中的各个元素为List类型,使用变量list指向引用的list数据。存入到res中的也是list指向的数据。
为什么在我遇到的问题中,遍历result会返回空,是因为arrayList作为方法的参数,方法结束时栈帧被回收,其中的所有内容包括局部变量表不再有效。所以result指向的list都为空。