题目
输出自然数 1 到 n 所有不重复的排列,即 n 的全排列,要求所产生的任一数字序列中不允许出现重复的数字。
输入
n(1≤n≤9)
输出
由 1~n 组成的所有不重复的数字序列,每行一个序列。
样例输入#1
3
样例输出#2
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 a[10], k[10], n;
void dfs(int step) {
if(step == n + 1) {
for(int i = 1; i <= n; i++)
cout << a[i] << " ";
cout << endl;
return;
}
for(int i = 1; i <= n; i++) {
if(k[i] == 0) {
a[step] = i;
k[i] = 1;
dfs(step + 1);
k[i] = 0;
}
}
return;
}
int main() {
cin >> n;
dfs(1);
return 0;
}