1199:全排列

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;
 } 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章