题目描述
小 A 的学校,老师好不容易解决了蓝桥杯的报名问题,现在老师又犯愁了。
现在有 N位同学参加比赛,但是老师想给他们排座位,但是排列方式太多了。
老师非常想弄明白最后的排座次的结果是什么样子的,到底有多少种结果。
请设计一个程序帮助老师。
最后输出各种情况的人名即可,一行一种情况,每种情况的名字按照报名即输入顺序排序。
输入描述
输入第一行包含一个整数 N。
接下来 N 行每行包含一个字符串Si,表示人名。
1≤N≤10。
输出描述
输出共若干行,每行输出各种情况的人名。一行一种情况,每种情况的名字按照报名即输入顺序排序。
输入输出样例
输入
3
xiaowang
xiaoA
xiaoli
输出
xiaowang xiaoA xiaoli
xiaowang xiaoli xiaoA
xiaoA xiaowang xiaoli
xiaoA xiaoli xiaowang
xiaoli xiaowang xiaoA
xiaoli xiaoA xiaowang
运行限制
- 最大运行时间:1s
- 最大运行内存: 128M
这道题是一道排列枚举问题, 对数组进行全排列有两种方法。一种是在算法书上分治算法那块学到的排列问题,另一种是学到的一个排列枚举的模板和书上的排列顺序不太一样。
先放上正确答案的代码:
#include <iostream>
#include<vector>
using namespace std;
vector<string> name;
int n;
int order[11];
int chosen[11];
void clc(int x){
if(x==n+1){
for(int i=1;i<=n;i++){
cout<<name[order[i]-1]<<" ";
}
cout<<endl;
}
for(int i=1;i<=n;i++){
if(chosen[i]) continue;
chosen[i]=1;
order[x]=i;
clc(x+1);
order[x]=0;
chosen[i]=0;
}
}
int main()
{
cin>>n;
for(int i=0;i<n;i++){
string s;
cin>>s;
name.push_back(s);
}
clc(1);
return 0;
}
还有改编算法书上全排列的代码,但是最后结果是和正确样例稍有偏差。
#include <iostream>
using namespace std;
string name[11];
int n;
void perm(int k,int m){
if(k==m) {
for(int i=0;i<=m;i++){
cout<<name[i]<<" ";
}
cout<<endl;
}
for(int j=k;j<=m;j++){
swap(name[k],name[j]);
perm(k+1,m);
swap(name[k],name[j]);
}
}
int main()
{
cin>>n;
for(int i=0;i<n;i++){
cin>>name[i];
}
perm(0,n-1);
return 0;
}