思路
回溯的思想:用一个i变量记录当前抉择数字所在位置,对于每一个数字,都有选或不选两种可能,如果选择当前数字,则i不变,并把当前数字加入链表当中,sum也加上当前数字的值;如果不选,则只需将i++。当ilen返回,当sumtarget时把当前的p加入答案。
解题过程
关键在于选或不选两种抉择怎么用代码表示
选:p.add(arr[i]); dfs(p,i,sum+arr[i]); p.remove(p.size()-1);
不选:dfs(p,i+1,sum); //相当于直接跳过
Code
class Solution {
List<List<Integer>> list=new ArrayList<>();
public int tar;
public int len;
public int arr[];
public List<List<Integer>> combinationSum(int[] candidates, int target) {
len=candidates.length;
tar=target;
arr=new int[len];
arr=candidates;
List<Integer> p=new ArrayList<>();
dfs(p,0,0);
return list;
}
public void dfs(List<Integer> p,int i,int sum){
if(i==len) return;
if(sum==tar){
list.add(new ArrayList(p));
return;
}
if(sum<tar){
p.add(arr[i]);
dfs(p,i,sum+arr[i]);
p.remove(p.size()-1);
}
dfs(p,i+1,sum);
}
}
作者:菜卷
链接:https://leetcode.cn/problems/combination-sum/solutions/2897900/zu-he-zong-he-by-ashi-jian-chong-dan-lia-imuy/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。