题目:
给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。
candidates 中的数字可以无限制重复被选取。
示例:
解法
有时候剪枝不止需要加上附加条件,还需要对原有数据集进行改动,比如排序。
代码
class Solution {
public:
vector<int> path;
vector<vector<int>> res;
void traversal(vector<int>& candidates, int target, int sum, int Index) {
if (sum > target) {
return;
}
if (sum == target) {
res.push_back(path);
return;
}
//递归逻辑:遍历candidates,并加上了剪枝
for (int i = Index; i < candidates.size() && sum + candidates[i] <= target; i++) {
sum += candidates[i];
path.push_back(candidates[i]);
traversal(candidates, target, sum, i);
sum -= candidates[i];
path.pop_back();
}
}
vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
path.clear();
res.clear();
sort(candidates.begin(), candidates.end());
traversal(candidates, target, 0, 0);
return res;
}
};