HDU1880 魔咒词典
题目大意:对应的输入多行,每行两个字符串,两个字符串互相映射。接下来询问的时候,如果这个字符串出现过,输出其对应的字符串。
分析:二重哈希来判断字符串是否存在,输出其对应的字符串就行。二重哈希的入门题,字符串还挺有意思的。
代码:
#include<iostream>
#include<string>
#include<map>
#include<string>
using namespace std;
typedef unsigned long long ull;
map<pair<int,int>,string> dict;
const int s1=,s2=;
const int maxn=1e5+;
char s[],t[];
int hash1(char* s){
int ans=;
for(int i=;s[i];i++)
ans=(ans*s1+s[i])%maxn;
return ans;
}
int hash2(char* s){
int ans=;
for(int i=;s[i];i++)
ans=(ans*s2+s[i])%maxn;
return ans;
}
void read(){
int cnt=;
while(scanf("%s",s)&&s[]!='@'){
getchar();
cnt=;
while((t[cnt]=getchar())!='\n')
cnt++;
t[cnt]='\0';
dict[make_pair(hash1(s),hash2(s))]=t;
dict[make_pair(hash1(t),hash2(t))]=s;
}
}
void solve(){
int m,x,y,cnt=;
scanf("%d",&m);
getchar();
while(m--){
cnt=;
while((s[cnt]=getchar())!='\n')
cnt++;
s[cnt]='\0';
x=hash1(s);
y=hash2(s);
if(s[]=='['){
if(dict.find(make_pair(x,y))==dict.end()) printf("what?\n");
else cout<<dict[make_pair(x,y)]<<endl;
}
else{
if(dict.find(make_pair(x,y))==dict.end()) printf("what?\n");
else cout<<dict[make_pair(x,y)].substr(,dict[make_pair(x,y)].length()-)<<endl;
}
}
}
int main(){
read(); solve(); return ;
}
HDU1880 魔咒词典的更多相关文章
- C++之路进阶——HDU1880(魔咒词典)
		
---恢复内容开始--- New~ 欢迎参加2016多校联合训练的同学们~ 魔咒词典 Time Limit: 8000/5000 MS (Java/Others) Memory Limit: 3 ...
 - HDU 1880 魔咒词典(字符串哈希)
		
题目链接 Problem Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一 ...
 - hdu 1880 魔咒词典
		
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1880 魔咒词典 Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有10 ...
 - HDU 1880  魔咒词典  (Hash)
		
魔咒词典 Time Limit: 8000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
 - 题目1029:魔咒词典(map使用以及字符串读取函数总结)
		
题目链接:http://ac.jobdu.com/problem.php?pid=1029 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus // // ...
 - hdu 1880 魔咒词典 (字符串哈希)
		
魔咒词典 Time Limit: 8000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
 - ACM1880魔咒词典
		
魔咒词典 Problem Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一 ...
 - HDU - 1880 魔咒词典~哈希入门
		
哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一个需要的魔咒,所以他需要你的帮助. 给你一部魔咒词 ...
 - 九度OJ 1029:魔咒词典 (排序)
		
时间限制:5 秒 内存限制:32 兆 特殊判题:否 提交:4574 解决:1318 题目描述: 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部 ...
 
随机推荐
- Notepad++查看文本文件的总的字符数、GBK字节数、UTF8字节数
			
如果其编码是 小结:UTF-8编码下,一个汉字占3字节,GBK编码下,一个汉字占2字节:
 - 「CF1313C Skyscrapers」
			
题目大意 给出一个长度为 \(N\) 的序列 \(a\) 需要构造出一个长度为 \(N\) 的序列 \(h\) 使得 \(\forall i \in \{1,2,\ldots ,N\} h_i \le ...
 - Hive的mysql安装配置
			
一.MySQL的安装 Hive的数据,是存在HDFS里的.此外,hive有哪些数据库,每个数据库有哪些表,这样的信息称之为hive的元数据信息. 元数据信息不存在HDFS,而是存在关系型数据库里,hi ...
 - nginx 重写 隐藏index.php
			
修改 nginx.conf 文件location / { if (!-e $request_filename) { rewrite ^(.*)$ /index.php?s=$1 last; break ...
 - win10 设置jdk环境变量
			
win10环境变量较为特殊 只需要设置JAVA_HOME和PATH,设置后可以通过java -version 和 javac -version 验证查看jdk得版本号和编译版本号 具体如下图所示:
 - 泛型和Object的区别?
			
泛型声明 public <T> T doSomeThing(T t){ return t; } Object声明 public Object doSomeThing(Object obj) ...
 - 新手如何配置 Chromedriver 环境变量
			
有一个不错的链接:https://blog.csdn.net/qq_41429288/article/details/80472064
 - Periodic-table
			
1. Periodic table 1.1 元素的排列 1.2 表中的行与列 1.3 元素区块 1.4 周期表中的一些趋势 1.5 元素周期律的本质 1.6 电子排布 2. 更多相关链接 2.1 维基 ...
 - 把链接生成二维码 二维码中间带有logo
			
在工程中引入三个文件jquery.qrcode.js.qrcode.js.utf.js.其中utf.js文件是防止链接中的参数出现中文乱码现象 jquery.qrcode.js文件 function ...
 - Java日期时间API系列11-----Jdk8中java.time包中的新的日期时间API类,使用java8日期时间API重写农历LunarDate
			
通过Java日期时间API系列7-----Jdk8中java.time包中的新的日期时间API类的优点,java8具有很多优点,现在网上查到的农历转换工具类都是基于jdk7及以前的类写的,下面使用ja ...