题目描述
按照字典序输出自然数 1 到 n 所有不重复的排列,即 n 的全排列,要求所产生的任一数字序列中不允许出现重复的数字
输入
一个整数 n(1<=n<=6)
输出
输出n个数的全排列
样例输入
3
样例输出
1 2 3 1 3 2 2 1 3 2 3 1 3 1 2 3 2 1
代码:
#include <bits/stdc++.h>
using namespace std;
int vis[1000010];//判断数是否选择过
int n;
int ans[1000010];//记录答案
void dfs(int now,int dijige){
ans[dijige]=now;//记录答案(排列)的第几个为now
if(dijige==n){//如果搜索到第n个输出排列
for(int i = 1;i <=n;i++){
cout << ans[i]<<" ";
}
cout << "\n";
}
for(int i = 1;i<=n;i++){
if(vis[i]==0){//如果i未被使用进行深搜
vis[i]=1;//将i标记
dfs(i,dijige+1);//深搜i
vis[i]=0;//回溯
}
}
}
int main(){
cin >> n;
for(int i = 1;i<=n;i++){
vis[i]=1;
dfs(i,1);
vis[i]=0;//回溯
}
return 0;
}