找出所有相加之和为 n 的 k 个数的组合。组合中只允许含有 1 - 9 的正整数,并且每种组合中不存在重复的数字。
说明:
所有数字都是正整数。
解集不能包含重复的组合。
示例 1:
输入: k = 3, n = 7
输出: [[1,2,4]]
示例 2:
输入: k = 3, n = 9
输出: [[1,2,6], [1,3,5], [2,3,4]]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/combination-sum-iii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution {
public:
int k;
vector<vector<int>> combinationSum3(int k, int target) {
this->k = k;
vector<vector<int>> ret;
vector<int> tmp;
vector<int> nums;
for(int i = 1; i <= 9; i++)
{
nums.push_back(i);
//cout<<i<<endl;
}
backtrack(ret, tmp, nums, 0,target);
return ret;
}
void backtrack(vector<vector<int>>& ret, vector<int> &tempList, vector<int>& nums, int start,int target)
{
//ret.push_back(tempList);
if(target < 0)
return;
else if(target == 0)
{
if(tempList.size() == k)
ret.push_back(tempList);
}
else
{
for(int i = start; i < nums.size(); i++)
{
tempList.push_back(nums[i]);
backtrack(ret, tempList, nums, i+1,target-nums[i]);
tempList.erase(tempList.begin() + tempList.size() - 1);
}
}
}
};