#include<iostream>
using namespace std;
const int N=11;
int n;
int path[N];
bool st[N];
void dfs(int u){
if(u==n){
for(int i=0;i<n;i++) printf("%d ",path[i]);
puts("");
}
for(int i=1;i<=n;i++){
if(!st[i]){
path[u] = i;
st[i] = true;
dfs(u+1);
st[i] = false;
}
}
}
int main(){
scanf("%d",&n);
dfs(0);
}
递归实现排列类枚举(c++实现)
最新推荐文章于 2024-07-25 12:39:48 发布