赞
踩
给定一个由不同的小写字母组成的字符串,输出这个字符串的所有全排列。
我们假设对于小写字母有’a’ < ‘b’ < … < ‘y’ < ‘z’,不保证给定的字符串中的字母按照从小到大的顺序排列。
多组输入,请读到文件结束为止
每行是一个由不同的小写字母组成的字符串,已知字符串的长度在1到6之间。
输出这个字符串的所有排列方式,每行一个排列。要求字母序比较小的排列在前面。字母序如下定义:
已知S = s1s2…sk , T = t1t2…tk,则S < T 等价于,存在p (1 <= p <= k),使得
s1 = t1, s2 = t2, …, sp - 1 = tp - 1, sp < tp成立。
注意每组样例输出结束后接一个空行。
xyz
xyz
xzy
yxz
yzx
zxy
zyx
这道题用next_permutation有两个坑点,一个是要去重,一个是要排序,这样一来就很简单了:
#include<bits/stdc++.h> using namespace std; int main() { map<string,int>m; char s[10]; while(cin >> s) { int k=strlen(s); sort(s,s+k); do { if(m[s]==0) cout << s<<endl; m[s]=1; } while (next_permutation(s, s + k)); cout<<endl; } }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。