给定一个数组 candidates
和一个目标数 target
,找出 candidates
中所有可以使数字和为 target
的组合。
candidates
中的每个数字在每个组合中只能使用一次。
说明:
- 所有数字(包括目标数)都是正整数。
- 解集不能包含重复的组合。
示例 1:
输入: candidates =[10,1,2,7,6,1,5]
, target =8
, 所求解集为: [ [1, 7], [1, 2, 5], [2, 6], [1, 1, 6] ]
示例 2:
输入: candidates = [2,5,2,1,2], target = 5, 所求解集为: [ [1,2,2], [5] ]
思路:和上一题一样点我,但是需要一点小的修改
1:需要对数组对进行排序,去除相同的组合
2:对于candidates[i]==candidates[i-1]相同的情况,不能跳过,因为是不同的元素
3:递归调用自身的范围不再是[start,end],而是[start+1,end]
参考代码:
class Solution {
public:
void combinationSumCore(vector<int>& candidates, int target, set<vector<int>> &res, vector<int> tmp, int sum, int start, int end) {
if (sum > target) {
return;
}
for (int i = start; i <= end; i++) {
tmp.push_back(candidates[i]);
sum += candidates[i];
if (sum < target) {
combinationSumCore(candidates, target, res, tmp, sum, i + 1, candidates.size() - 1);
}
else if (sum == target) {
res.insert(tmp);
}
tmp.pop_back();
sum -= candidates[i];
}
}
vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {
set<vector<int>> res;
vector<int> tmp;
int sum = 0;
sort(candidates.begin(), candidates.end());
combinationSumCore(candidates, target, res, tmp, sum, 0, candidates.size() - 1);
return vector<vector<int>>(res.begin(), res.end());
}
};
给定一个数组 candidates
和一个目标数 target
,找出 candidates
中所有可以使数字和为 target
的组合。
candidates
中的每个数字在每个组合中只能使用一次。
说明:
- 所有数字(包括目标数)都是正整数。
- 解集不能包含重复的组合。
示例 1:
输入: candidates =[10,1,2,7,6,1,5]
, target =8
, 所求解集为: [ [1, 7], [1, 2, 5], [2, 6], [1, 1, 6] ]
示例 2:
输入: candidates = [2,5,2,1,2], target = 5, 所求解集为: [ [1,2,2], [5] ]