1199:全排列
时间限制: 1000 ms 内存限制: 65536 KB
【题目描述】
给定一个由不同的小写字母组成的字符串,输出这个字符串的所有全排列。
我们假设对于小写字母有‘a’ <‘b’ < ... <‘y’<‘z’,而且给定的字符串中的字母已经按照从小到大的顺序排列。
【输入】
只有一行,是一个由不同的小写字母组成的字符串,已知字符串的长度在1到6之间。
【输出】
输出这个字符串的所有排列方式,每行一个排列。要求字母序比较小的排列在前面。字母序如下定义:
已知S=s1s2...sk,T=t1t2...tk,则S<T等价于,存在p(1≤p≤k),使得s1=t1,s2=t2,...,s(p−1)=t(p−1),sp<tp成立。
【输入样例】
abc
【输出样例】
abc
acb
bac
bca
cab
cba
【提示】
本题目禁止使用STL及包含可以使用的相关调用。
【来源】
No
#include<stdio.h>
#include<iostream>
#include<cstring>
using namespace std;
bool b[1001];//标记
char s[1001],as[1001]; //s存储原字符串 as存储排序方案
int len;
void dfs(int i)
{
for(int j=0;j<len;j++){
if(!b[s[j]]){//判断是否用过
b[s[j]]=1;
as[i]=s[j];
if(i==len-1) printf("%s\n",as);//长度达到输出
else dfs(i+1);//否则取下一个长度
b[s[j]]=0;//标记取消
}
}
}
int main()
{
scanf("%s",s);
len=strlen(s);
dfs(0);//从长度0开始搜索
return 0;
}
#include<stdio.h>
#include<iostream>
#include<cstring>
using namespace std;
char a[1001];
int b[1001],c[1001]={0};
int len;
void dfs(int n)
{
if(n==len){
for(int i=0;i<len;i++) cout<<a[b[i]];
cout<<endl;
}
for(int i=0;i<len;i++){
if(!c[i]){//判断是否用过
c[i]=1;
b[n]=i;
dfs(n+1);//取下一个长度
c[i]=0;//标记取消
}
}
}
int main()
{
scanf("%s",a);
len=strlen(a);
dfs(0);//从长度0开始搜索
return 0;
}
宏阳13130884377 发布了61 篇原创文章 · 获赞 1 · 访问量 1500 私信 关注