题目链接:【http://acm.hdu.edu.cn/showproblem.php?pid=1880】

中文题面,题意很简单;

题解: 把每个 魔咒 和 对应的功能分别Hash,然后分别映射到map<ULL,string>里面,(魔咒Hash值,对应的功能)和(对应功能Hash值,魔咒)。

Hash 方式采用最简单的那种Hash即可。

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn = 100 + 15;
  4. const int sed = 131;
  5. typedef unsigned long long ULL;
  6. unordered_map<ULL, string>mpa, mpb;
  7. char tmp[maxn], sa[maxn], sb[maxn];
  8. ULL get_Hash(char s[], int len)
  9. {
  10. ULL ret = 0;
  11. for(int i = 0; i < len; i++)
  12. {
  13. ret = ret * sed + s[i];
  14. }
  15. return ret;
  16. }
  17. int main ()
  18. {
  19. while(true)
  20. {
  21. gets(tmp);
  22. int len = strlen(tmp);
  23. if(!strcmp("@END@", tmp)) break;
  24. int cnt = 0, pos = 0;
  25. for(int i = 1; i < len; i++)
  26. {
  27. if(tmp[i] == ']')
  28. {
  29. pos = i + 2;
  30. break;
  31. }
  32. sa[cnt++] = tmp[i];
  33. }
  34. sa[cnt] = 0;
  35. ULL ta = get_Hash(sa, cnt);
  36. cnt = 0;
  37. for(int i = pos; i < len; i++)
  38. sb[cnt++] = tmp[i];
  39. sb[cnt] = 0;
  40. ULL tb = get_Hash(sb, cnt);
  41. mpa[ta] = (string)(sb);
  42. mpb[tb] = (string)(sa);
  43. }
  44. int N;
  45. scanf("%d", &N);
  46. gets(tmp);
  47. for(int i = 1; i <= N; i++)
  48. {
  49. gets(tmp);
  50. int len = strlen(tmp);
  51. if(tmp[0] == '[')
  52. {
  53. for(int i = 0; i < len; i++)
  54. tmp[i] = tmp[i + 1];
  55. tmp[len - 2] = 0;
  56. ULL T = get_Hash(tmp, len - 2);
  57. if(mpa.count(T))
  58. cout << mpa[T] << endl;
  59. else
  60. cout << "what?" << endl;
  61. continue;
  62. }
  63. ULL T = get_Hash(tmp, len);
  64. if(mpb.count(T))
  65. cout << mpb[T] << endl;
  66. else
  67. cout << "what?" << endl;
  68. }
  69. return 0;
  70. }

  

HDU 1880 简单Hash的更多相关文章

  1. HDU 1880 字符串hash 入门题

    Problem Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一个需要的魔 ...

  2. hdu 1880 字符串hash

    /*普通的hsah 由于元素太多 空间很小..hash碰撞很厉害.30分*/ #include<iostream> #include<cstdio> #include<c ...

  3. HDOJ-ACM1425 sort 简单hash应用

    其实快排也可以通过这个问题~不是考点 没想到考点是这个,简单hash应用,空间换时间 初始化一个长度为1000001的数组(由于数字的范围为[-500000,500000]) 如果存在这个数m,数组下 ...

  4. hdu 1496 Equations hash表

    hdu 1496 Equations hash表 题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1496 思路: hash表,将原来\(n^{4}\)降 ...

  5. HDU 1564 简单博弈 水

    n*n棋盘,初始左上角有一个石头,每次放只能在相邻的四个位置之一,不能操作者输. 如果以初始石头编号为1作为后手,那么对于每次先手胜的情况其最后一步的四周的编号必定是奇数,且此时编号为偶数,而对于一个 ...

  6. HDU——2112HDU Today(SPFA+简单Hash或map+前向星)

    HDU Today Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  7. HDU 1880 魔咒词典 (字符串hash)

    <题目链接> 题目大意: 就是每个字符串有一个配套的对应字符串,询问的时候,无论输出其中的哪一个字符串,输出另一个,如果不存在这个字符串,直接输出"what?". 解题 ...

  8. HDU 1880 魔咒词典 (Hash)

    魔咒词典 Time Limit: 8000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  9. hdu 4287Intelligent IME(简单hash)

    Intelligent IME Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

随机推荐

  1. JVM学习十二:JVM之性能监控工具

    前面我们学习了很多JVM相关的理论知识,那么本节将重点讲述的是工具的使用,正所谓:工欲善其事,必先利其器.因此,本节介绍常用的性能监控工具,用于性能监控和问题排查. 一.系统性能监控 系统性能工具用于 ...

  2. css单位em、px、rem和pt的区别

    1.PX :像素(Pixel) PX是相对长度单位,它是相对于显示器屏幕分辨率而言的. 优缺点:比较稳定和精确,但在浏览器中放大或缩放浏览页面时会出现页面混乱的情况. 2.EM:是相对长度单位. EM ...

  3. Web应用程序完全测试指南

    随着Web技术和移动互联网的发展,越来越多的应用被迁移到了云端,这也使得用户可以随时随地使用它们.目前大量的优质应用,逐渐提升了用户的品味,也降低了用户的容忍度,如果你的Web应用无法使用户满意,那么 ...

  4. 简易版jquery

    最近写了一个简易版的jquery   github地址:https://github.com/jiangzhenfei/Easy-Jquery 完成的方法: 1.$('#id') 2.extend扩展 ...

  5. 爬虫实战--基于requests 和 Beautiful的7160美图网爬取图片

    import requests import os from bs4 import BeautifulSoup import re # 初始地址 all_url = 'http://www.7160. ...

  6. python3学习笔记.3.条件控制与循环

    1.条件控制 关键字 if.elif.else 一般形式如下: if 条件1: 结果1 elif 条件2: 结果2 else: 结果3 注意:条件后的:语句的缩进的是相同的   2.循环语句 关键字有 ...

  7. 蓝色的oa模板html_综合信息服务管理平台OA模板——后台

    链接:http://pan.baidu.com/s/1qXGGOAK 密码:2otu

  8. CSS 中 nth-child 和 nth-of-type 的区别

    假设有如下代码结构,想要查找 Piggy 那个 p <section> <h1>Words</h1> <p>Little</p> <p ...

  9. Wireshark过滤语句中常用的操作符

    关键字有: eq,== 等于ne,!= 不等于gt,> 比…大lt,< 比…小 ge,>= 大于等于le,<= 小于等于 and,|| 且 or,&& 或 no ...

  10. CTF AWD模式攻防Note

    ###0x01 AWD模式 Attack With Defence,简而言之就是你既是一个hacker,又是一个manager.比赛形式:一般就是一个ssh对应一个web服务,然后flag五分钟一轮, ...