题目描述:
找出所有相加之和为 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]]
算法:
回溯法
class Solution {
public:
vector<vector<int>> combinationSum3(int k, int n) {
vector<vector<int>>ans;
vector<int>col;
if(k<=0 || k>9)
return ans;
vector<int>nums;
for(int i=1;i<10;i++)
nums.push_back(i);
dfs(nums, ans, col, k, n, 0);
return ans;
}
void dfs(vector<int>&nums, vector<vector<int>>&ans, vector<int>&col,int k,int n,int index)
{
if(n == 0 && col.size() == k)
{
ans.push_back(col);
return ;
}
if(col.size() == k)
return ;
for(int i=index;i<nums.size();i++)
{
if(n-nums[i]>=0)
{
col.push_back(nums[i]);
dfs(nums, ans, col,k, n-nums[i], i+1);
col.pop_back();
}
}
}
};