字符串排序

hihoCoder

一般我们在对字符串排序时,都会按照字典序排序。当字符串只包含小写字母时,相当于按字母表"abcdefghijklmnopqrstuvwxyz"的顺序排序。  

现在我们打乱字母表的顺序,得到一个26个字母的新顺序。例如"bdceafghijklmnopqrstuvwxyz"代表'b'排在'd'前,'d'在'c'前,'c'在'e'前……  

给定N个字符串,请你按照新的字母顺序对它们排序。

Input

第一行包含一个整数N。(1 <= N <= 1000)

第二行包含26个字母,代表新的顺序。

以下N行每行一个字符串S。 (|S| <= 100)

Output

按新的顺序输出N个字符串,每个字符串一行。

Sample Input

5
bdceafghijklmnopqrstuvwxyz
abcde
adc
cda
cad
ddc

Sample Output

ddc
cda
cad
abcde
adc
#include
using namespace std;
const int N=1e3+3;
char t[N],s[N];
int b[N];
struct dd
{
    int id;
    char ss[N];
}w[N];
bool cmp(dd q,dd p)
{
	if(strcmp(q.ss,p.ss)!=0)
	return strcmp(q.ss,p.ss)<=0;
	else return q.id

你可能感兴趣的:(思维,c++)