找出所有相加之和为 n
的 k
个数的组合,且满足下列条件:
- 只使用数字1到9
- 每个数字 最多使用一次
返回 所有可能的有效组合的列表 。该列表不能包含相同的组合两次,组合可以以任何顺序返回。
示例 1:
输入: k = 3, n = 7 输出: [[1,2,4]] 解释: 1 + 2 + 4 = 7 没有其他符合的组合了。
#include <stdio.h>
#define N 500
int path[N];
//从【begin,n】挑选一个数字填充第k位
int i,top=0;
void dfs(int target,int k,int sum,int startindex){
if (top==k && sum==target){
for (int i = 0; i < k; ++i) {
printf("%d ",path[i]);
}
printf("\n");
return;
}
for (int i = startindex; i <= 9 ; ++i) {
sum+=i;
path[top++]=i;
dfs(target,k,sum,i+1);
sum-=i;
top--;
}
}
int main()
{
dfs(7,3,0,1);
return 0;
}