2020年字符串专题训练赛03

D:魔咒词典
题目大意:每一个单词都对应着一个功能,当哈里说出这个魔咒时,你必须可以给出响应的功能,如果没有则输出“what?”
刚开始看到题目,就想到了字典树的方言翻译那个板子题
但是仔细思考了一下,会不会写map更容易
但是写完交完就。。。
[图片]
因为如果字符串很长的话,就会超内存
因次训练的时候就gg了
看了题解后发现hash+二分的方法非常有用
因此就自己写了一遍,确实是有点麻烦

#include<bits/stdc++.h>
using namespace std;
struct node
{
	int hash;//记录hash值 
	int loc;//记录此时的hash值的位置 
}code[1000],decode[1000]; 
int cmp(node a,node b)
{
	return a.hash<b.hash;
}
unsigned int get_hash(string s)
{
	int t=1;
	int base=131;
	for(int i=0;i<s.size();i++)
	t=t*base+s[i];
}

int main()
{
	int num=0;
    while(1)
    {
    	cin>>code[num]>>decode[num];
    	code1[num]=code[num];
    	decode1[num]=decode[num];
    	code[num].loc=decode[num].loc=num;
    	if(strcmp(code1[num],'@END@')==0)
    	break;
    	code[num].hash=get_hash(code[num]);
    	decode[num].hash=get_hash(decode[num]);
    	num++;
	}
	sort(code,code+num,cmp);
	sort(decode,decode+num,cmp);
	int n;
	cin>>n;
	while(n--)
	{
		string s;
		cin>>s;
		node t;
		if(s[0]=='[')
		{
			t.hash=get_hash(s);
			 int mid=lower_bound(code,code+num,t,cmp)-code;
			 if(code[mid].hash!=t.hash);
			 cout<<"What?"<<endl;
			 else
70                 printf("%s\n",decode1[code[mid].l]);
		}
		 else
73         {
74             t.Hash=get_hash(s);
75             int mid=lower_bound(decode,decode+num,t,cmp)-decode;
76             if(decode[mid].Hash!=decode.Hash)
77                 printf("what?\n");
78             else
79             {
80                 int l=strlen(code1[decode[mid].l]);//处理咒语两边的方括号
81                 code1[decode[mid].l][l-1]=0;
82                 printf("%s\n",code1[decode[mid].l]+1);
83             }
84     }
	}
 } 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值