一个单词a如果通过交换单词中字母的顺序可以得到另外的单词b,那么定义b是a的Anigram,例如单词army和mary互为Anigram。现在给定一个字典,输入Q个单词,从给出的字典中找出这些单词的Anigram。
Input
第1行:1个数N,表示字典中单词的数量。(1 <= N <= 10000) 第2 - N + 1行,字典中的单词,单词长度 <= 10。 第N + 2行:查询的数量Q。(1 <= Q <= 10000) 第N + 3 - N + Q - 2行:用作查询的单词,单词长度 <= 10。
Output
共Q行,输出Anigram的数量,相同的2个单词不算Anigram,如果没有输出0。
Input示例
5 add dad bad cad did 3 add cac dda
Output示例
1 02
直接map搞定
#include<stdio.h> #include<iostream> #include<algorithm> #include<map> #include<string.h> using namespace std; map<string,int>a; map<string,int>b; int flag[60]; int main() { char ss='a'; int n,i,j,k,sum,m; char ch[60],str[20]; scanf("%d",&n); while(n--) { scanf("%s",str); a[str]++; for(i=1;i<=60;i++) ch[i]='0'; memset(flag,0,sizeof(flag)); for(i=0;str[i]!='\0';i++) { int x=str[i]-'A'+1; flag[x]++; ch[x]=flag[x]+'0'; } b[ch+1]++; } scanf("%d",&m); while(m--) { scanf("%s",str); for(i=1;i<=60;i++) ch[i]='0'; memset(flag,0,sizeof(flag)); for(i=0;str[i]!='\0';i++) { int x=str[i]-'A'+1; flag[x]++; ch[x]=flag[x]+'0'; } printf("%d\n",b[ch+1]-a[str]); } return 0; }