39. 组合总和 - 力扣(LeetCode)
回溯:
java
class Solution {
public List<List<Integer>> combinationSum(int[] candidates,int target) {
List<List<Integer>> ans = new ArrayList<>();
List<Integer> combine = new ArrayList<>();
dfs(candidates,target,ans,combine,0);
return ans;
}
private void dfs(int[] candidates, int target,List<List<Integer>> ans,List<Integer> combine,int index){
if(index == candidates.length){
return;
}
if(target == 0){
//记得要用new
ans.add(new ArrayList<>(combine));
return;
}
//往深处找
dfs(candidates,target,ans,combine,index+1);
if(target-candidates[index]>=0){
combine.add(candidates[index]);
//看看可不可以重复选
dfs(candidates,target-candidates[index],ans,combine,index);
//动态数组长度是size()
combine.remove(combine.size()-1);
}
}
}
时间复杂度:O(S) S 为所有可行解的长度之和
空间复杂度:O(target/min) 递归栈的深度