题目来源:http://poj.org/problem?id=1256
题目大意是求字符串的全排列 要求按A<a<B<b<...<Z<z 的顺序输出
那就把给定的字符串先排序
然后通过STL的next_permutation函数生成全排列(C++)
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
bool cmp(char a, char b)
{
int asc1, asc2;
asc1 = (a >= 'a' && a <= 'z') ? (a - 'a')*2 + 1 : (a - 'A')*2;
asc2 = (b >= 'a' && b <= 'z') ? (b - 'a')*2 + 1 : (b - 'A')*2;
return asc1 < asc2;
}
int main()
{
int total, len;
char str[13];
scanf("%d", &total);
while(total--)
{
scanf("%s", str);
len = strlen(str);
sort(str,str+len,cmp);
printf("%s\n", str);
while(next_permutation(str, str+len,cmp))
printf("%s\n", str);
}
}
本文详细介绍了如何使用STL的next_permutation函数生成给定字符串的所有全排列,并按特定顺序输出。通过实例演示了从输入字符串排序到生成全排列的完整过程。
867

被折叠的 条评论
为什么被折叠?



