排列与组合是常用的数学方法,其中组合就是从nn个元素中抽出rr个元素(不分顺序且r \le n)r≤n),我们可以简单地将nn个元素理解为自然数1,2,…,n1,2,…,n,从中任取rr个数。
现要求你输出所有组合。
例如n=5,r=3n=5,r=3,所有组合为:
1 2 3 , 1 2 4 , 1 2 5 , 1 3 4 ,1 3 5 , 1 4 5 , 2 3 4 , 2 3 5 , 2 4 5 , 3 4 5
123,124,125,134,135,145,234,235,245,345
思路:深搜加回溯,每次搜索时从上一个数加1开始循环,这样得到的就是递增的组合
上代码
#include<bits/stdc++.h>
using namespace std;
int n,r,a[100];
void dfs(int k){
if(k>r){ //递归结束
for(int i=1;i<=r;i++){
printf("%3d",a[i]);
}
printf("\n");
return; //记得回溯,不然回输出重复数据;
}
for(int i=a[k-1]+1;i<=n;i++){//从上一个使用的数加一开始循环
a[k]=i; //将i赋值给当前位置
dfs(k+1);//继续搜索下一个数
}
}
int main(){
cin>>n>>r;
dfs(1);
return 0;
}