51 nod 1095 Anigram单词 利用map处理hash问题

来源:互联网 发布:来钱快软件 编辑:程序博客网 时间:2024/06/06 03:28
一个单词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示例
5adddadbadcaddid3addcac

dda

我们准备两个map,第一的存储所有输入值出现的个数。 第二个存储每个输入值排序后出现的个数。

那么对于某一个字符,我们排序后的减去它本身出现的次数,就是anigram的次数了。

例题:

我们map1 存入

add 1dad 1bad 1cad 1did 1
而map2对应这

add 3

acd 1

ddi 1


我们查询add时,add在原式出现过一次,在查询add排序后出现了3次, 3-1 =2

我们查询dad时,dad在原式出现过一次,在查询dad时排序为add,出现了3次。 3-1=2

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<limits.h>
#include<iostream>
#include<queue>
#include<math.h>
#include<stack>
#include<vector>
#include<algorithm>
#include<map>
using namespace std;


int main()
{
    map<string,int>mp1,mp2;
    char str[110];
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>str;
        int len=strlen(str);
        mp1[str]++;
        sort(str,str+len);
        mp2[str]++;
    }
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>str;
        int sum1=mp1[str];
        int len=strlen(str);
        sort(str,str+len);
        int sum2=mp2[str];
        cout<<sum2-sum1<<endl;
    }
}