递归实现指数型、组合型、排列型枚举
枚举的顺序很重要,要做到不重不漏:
1、依次枚举每个位置应该放哪个数
2、依次枚举每个数应该放到哪个位置
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=20;
int n;
int st[N];//记录选还是不选 0表示考虑中,1选择,2不选择
void dfs(int x){
if(x>n){
for(int i=1;i<=n;i++){
if(st[i]==1){
cout<<i<<" ";
}
}
cout<<endl;
return ;
}
st[x]=1;//选i
dfs(x+1);
st[x]=0;//恢复现场
st[x]=2;//不选i
dfs(x+1);
st[x]=0;
}
int main(){
cin>>n;
dfs(1);
return 0;
}
递归搜索树
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int N=25;
int n,m;//从n个里面选m个
int arr[N];//记录答案
void dfs(int x,int start){//形参代表第几层,和这一层从那个数开始枚举
//剪枝
if((x-1)+(n-start+1)<m) return ;
//当前选的数加上剩下的数的数量比层数小,说明不足以填满
if(x>m){//选m个,共m层
for(int i=1;i<=m;i++){
cout<<arr[i]<<" ";
}
cout<<endl;
return ;//这句话一定要有,否则会有重复值
}
for(int i=start;i<=n;i++){//一共有n个数可以枚举
arr[x]=i;
dfs(x+1,i+1);
arr[x]=0;
//要保证后一个数比前一个数字大,所以传给下一层的起始数字要+1
}
}
int main(){
cin>>n>>m;
dfs(1,1);//从第一层开始,从1开始枚举
return 0;
}
递归搜索树
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int N=10;
int n;
int arr[N];//记录答案
bool st[N];//默认为false 默认没有选过
void dfs(int x){//这是第x层
if(x>n){//最深处之后
for(int i=1;i<=n;i++){//下标从1开始,因为从第一层开始算起
cout<<arr[i]<<" ";
}
cout<<endl;
}
for(int i=1;i<=n;i++){//从1开始赋值
if(!st[i])//这个没被选择过
{
st[i]=true;//标记选择
arr[x]=i;
dfs(x+1);//进入下一层
//从下一层回来,恢复现场
st[i]=false;
}
}
}
int main(){
cin>>n;
dfs(1);
return 0;
}
递归搜索树图片: