题目链接:LeetCode 39. 组合总和
题意:
给定一个无重复元素的数组 candidates
和一个目标数 target
,找出 candidates
中所有可以使数字和为 target
的组合。
candidates
中的数字可以无限制重复被选取。
说明:
- 所有数字(包括
target
)都是正整数。 - 解集不能包含重复的组合。
示例 1:
输入:candidates =[2,3,6,7],
target =7
, 所求解集为: [ [7], [2,2,3] ]
解题思路:
使用深度优先搜索,回溯判断
注:一定注意数字范围,如果数组中有0,需要特殊判断,否则一直到不了target,那么会一直会进行回溯,陷入死循环
class Solution {
public:
vector<vector<int>> ans;
vector<int> path;
void dfs(vector<int>& candidates, int target, int sum, int index) {
if(sum > target) { // 如果大于,不满足
return ;
}
if(sum == target) { // 如果和等于目标,返回
ans.push_back(path);
return ;
}
for(int i = index; i < candidates.size(); i++) {
sum += candidates[i]; // 如果小于和,加上
path.push_back(candidates[i]); // 将其push进数组
dfs(candidates, target, sum, i); // 进行深度搜索
sum -= candidates[i]; // 从上一层返回的回到这里,然后和减去当前数字
path.pop_back(); // pop出
}
}
vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
dfs(candidates, target, 0, 0);
return ans;
}
};