/*
给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合。
candidates 中的数字可以无限制重复被选取。
说明:
所有数字(包括 target)都是正整数。
解集不能包含重复的组合。
示例 1:
示例 1:
输入:candidates =[2,3,6,7],
target =7
, 所求解集为: [ [7], [2,2,3] ]
*/
#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
void backTrack(vector<int> &candidates, vector<vector<int>> &ans, int start, vector<int> &temp, int target)
{
if (target < 0) return; // 已经爆了
if (target == 0) // 刚好合适
{
ans.push_back(temp);
return;
}
for (int i = start; i < candidates.size(); i++)
{
if (candidates[i] > target)// 后面全是大于target的,直接跳出
break;
temp.push_back(candidates[i]);
backTrack(candidates, ans, i, temp, target - candidates[i]);
temp.pop_back();
}
}
vector<vector<int>> combinationSum(vector<int>& candidates, int target)
{
sort(candidates.begin(), candidates.end());
vector<vector<int>> ans;
vector<int> temp;
backTrack(candidates, ans, 0, temp, target);
return ans;
}
int main()
{
int num;
int n;
vector<int> s;
int target;
cout << "输入目标值";
cin >> target;
while (cin>>num&&num!='#') {
s.push_back(num);
}
vector<vector<int>> result;
result = combinationSum(s, target);
for (int i = 0; i < result.size(); i++) {
cout << "[";
for (int j = 0; j < result[i].size(); j++) {
cout << result[i][j] << " ";
}
cout << "]";
cout << endl;
}
return 0;
}