COGS 2082. Asm.Def谈笑风生
★ 输入文件:asm_talk.in
输出文件:asm_talk.out
简单对比
时间限制:2 s 内存限制:256 MB
【题目描述】
“人呐都不知道,自己不可以预料,直升机刚一出圣地亚哥就把我丢到你们船上,说中央已经决定了,让我来帮忙监听无线电信号……”
美国海军“无蛤”号电子测量船的船长,斯科特·华莱士继续把玩着手中的鸭嘴笔,“咱们就在你要监听的那个人工智能舰队眼皮底下,你怎么知道这么作死没问题?”
“管它呢,我告诉你一点人生的经验,有事就坐那个撤,”Asm.Def瞟了一眼窗外为“无蛤”号护航的151“雪风”号驱逐舰,“它跑得比谁都快。”
华莱士的内心此时是崩溃的。“来人,把Asm.Def塞进意大利炮,打出去。我从未见过有如此厚颜……”
“住手!”Asm.Def大喊。
“我们在圣地亚哥找到的数据表明,人工智能发出的无线电信号遵循一定模式,据此可以预测它们的行动。”
Asm.Def检测到了一系列无线电信号,每个信号都是由小写字母组成,长度<=20的字符串。他有时会查询,某个字符串T是否已被检测到。T中可能会包含一个通配符“*”,代表这一位可以是任意字母。
【输入格式】
第一行一个整数m,表示操作数量。
接下来m行每行一个操作,为如下两种之一:
1 S:表示Asm.Def新检测到了一个信号S。
2 T:表示查询信号T是否已被检测到。有则输出“YES”,否则输出“NO”。T中至多包含一个通配符“*”。
【输出格式】
对每个2操作,输出一行“YES”或“NO”。
【样例输入】
6
1 ab
2 ab*
1 abc
1 adc
2 *d
2 abc
【样例输出】
NO
NO
YES
【提示】
数据范围:
70%的数据,m<=1000.
100%的数据,m<=10^5.
S、T都是长度不超过20的小写字母串,但T中可能包含通配符。
【来源】
在此键入。
mmp 气死我了
mmp 气得我都splay了
mmp 本来写的好好的trie树 本地测试各种过,评测机测试各种WA
mmp 强行改的set
mmp trie树代码理论上过了。。(无用的自我安慰)
#include <iostream>
#include <cstdio>
#include <string>
#include <set> using namespace std;
int n;
string a;
set<string>se;
bool find_(string b)
{
if(se.count(b) )
return true;
for(int i=b.size();~i;i--)
{
if(b[i]=='*')
{
for(int j=;j<;j++)
{
b[i]=j+'a';
if(se.count(b) ) return true;
}
}
}
return false;
}
int main()
{
freopen("asm_talk.in","r",stdin);
freopen("asm_talk.out","w",stdout);
scanf("%d",&n);
for(int opt;n--;)
{
scanf("%d",&opt);
cin>>a;
if(opt==) se.insert(a);
else find_(a)?printf("YES\n"):printf("NO\n");
}
return ;
}
理论上过的trie树。。
#include <iostream>
#include <cstring>
#include <string>
#include <cstdio>
using namespace std;
struct node
{
int cnt;
node * next[];
bool exict;
}*root;
int tot=,m;
node * create()
{
node * rt=new node;
memset(rt->next,,sizeof(rt->next));
rt->cnt=;
rt->exict=;
return rt;
}
void ins(string a)
{
node *p=root;
for(int i=;i<a.length();i++)
{
int id=a[i]-'a'+;
if(p->next[id]==)
p->next[id]=create();
p=p->next[id];
p->cnt++;
}
p->exict=;
}
int search(string a)
{
node *p=root;
for(int i=;i<a.length();i++)
{
int id=a[i]-'a'+;
p=p->next[id];
if(p==NULL) return ;
}
if(p->exict) return ;
}
int main()
{
freopen("asm_talk.in","r",stdin);
freopen("asm_talk.out","w",stdout);
root=create();
scanf("%d",&m);
string sign;
for(int opt;m--;)
{
scanf("%d",&opt);cin>>sign;
if(opt==)
{
int k=sign.find('*');
if(k!=-)
{
for(int i=;i<=;i++)
{
sign[k]=i+'a';
ins(sign);
}
}
else ins(sign);
}
else
{
int k=sign.find('*');
bool flag=false;
if(k!=-)
{
for(int i=;i<=;i++)
{
sign[k]=i+'a';
if(search(sign))
{
printf("YES\n");
flag=true;
break;
}
}
if(!flag) printf("NO\n");
}
else search(sign)?printf("YES\n"):printf("NO\n");
}
}
return ;
}
COGS 2082. Asm.Def谈笑风生的更多相关文章
- Asm.Def谈笑风生
★ 输入文件:asm_talk.in 输出文件:asm_talk.out简单对比时间限制:2 s 内存限制:256 MB [题目描述] “人呐都不知道,自己不可以预料,直升机刚一出圣地亚哥 ...
- COGS——T2084. Asm.Def的基本算法
http://cogs.pro/cogs/problem/problem.php?pid=2084 ★☆ 输入文件:asm_algo.in 输出文件:asm_algo.out 简单对比时间 ...
- COGS——C2098. Asm.Def的病毒
http://www.cogs.pro/cogs/problem/problem.php?pid=2098 ★☆ 输入文件:asm_virus.in 输出文件:asm_virus.out ...
- cogs——2098. Asm.Def的病毒
2098. Asm.Def的病毒 ★☆ 输入文件:asm_virus.in 输出文件:asm_virus.out 简单对比时间限制:1 s 内存限制:256 MB [题目描述] “这就 ...
- COGS 2091. Asm.Def的打击序列
★★★ 输入文件:asm_lis.in 输出文件:asm_lis.out 简单对比时间限制:4 s 内存限制:256 MB [题目描述] 白色圆柱形的“蓝翔”号在虚空中逐渐变大,一声沉 ...
- COGS 2084. Asm.Def的基本算法
★☆ 输入文件:asm_algo.in 输出文件:asm_algo.out 简单对比时间限制:1 s 内存限制:256 MB [题目描述] “有句美国俗语说,如果走起来像鸭子,叫起来像 ...
- COGS 2098. Asm.Def的病毒
★☆ 输入文件:asm_virus.in 输出文件:asm_virus.out 简单对比时间限制:1 s 内存限制:256 MB [题目描述] “这就是我们最新研制的,世界上第一种可持 ...
- cogs——2084. Asm.Def的基本算法
2084. Asm.Def的基本算法 ★☆ 输入文件:asm_algo.in 输出文件:asm_algo.out 简单对比时间限制:1 s 内存限制:256 MB [题目描述] “有句 ...
- cogs 2098. [SYOI 2015] Asm.Def的病毒 LCA 求两条路径是否相交
2098. [SYOI 2015] Asm.Def的病毒 ★☆ 输入文件:asm_virus.in 输出文件:asm_virus.out 简单对比时间限制:1 s 内存限制:256 M ...
随机推荐
- JSP页面无法识别EL表达式
昨天一直纠结一个问题,JSP页面无法获取${user}的值,一直显示的是${user},今天解决了,原来是JSP页面无法识别EL表达式. 我的web.xml的声明如下: <!DOCTYPE we ...
- 3-C++程序的结构1.2
对象的生存周期 可以分为静态生存周期和动态生存周期 1.静态生存周期 如果对象的生存期与程序的运行期相同,我们称它具有静态生存期.在文件作用域中声明的对象都具有静态生存期的.如果要在函数的块中声明具有 ...
- java集合框架之ArrayList与LinkedList的区别
参考http://how2j.cn/k/collection/collection-arraylist-vs-linkedlist/690.html#nowhere ArrayList和LinkedL ...
- E20180525-hm
sensitive adj. 敏感的; 感觉的; [仪] 灵敏的; 易受影响的; lookup v. 查找; 查表; speedy adj. 快的,迅速的; 敏捷的 marshal vt. 整理, ...
- [Xcode 实际操作]八、网络与多线程-(4)使用UIApplication对象发送短信
目录:[Swift]Xcode实际操作 本文将演示如何使用应用程序单例对象,发送短信的功能. 在项目导航区,打开视图控制器的代码文件[ViewController.swift] 注:需要使用真机进行测 ...
- IT兄弟连 JavaWeb教程 JSTL定义
JSTL标签库实际上包含5个不同的标签库.JSTL1.1规范为这些标签库的URI和前缀做了预定,参见表7.3. 表3 JSTL标签库
- Elasticsearch and MongoDb
http://www.linkedin.com/groups/Difference-between-elasticsearch-MongoDB-3393294.S.588764405916973056 ...
- [题解](tarjan割点/点双)luogu_P3225_矿场搭建
首先和割点有关,求割点,然后这些割点应该把这个图分成了多个点双,可以考虑点双的缩点,假如缩点做的话我们要分析每个点双的性质和贡献 先拿出一个点双来,如果它没有连接着割点,那么至少要建两个,以防止其中一 ...
- [題解] luogu p1220 關路燈
區間dp 题目描述 某一村庄在一条路线上安装了n盏路灯,每盏灯的功率有大有小(即同一段时间内消耗的电量有多有少).老张就住在这条路中间某一路灯旁,他有一项工作就是每天早上天亮时一盏一盏地关掉这些路灯. ...
- Maximum Control (medium) Codeforces - 958B2
https://codeforces.com/contest/958/problem/B2 题解:https://www.cnblogs.com/Cool-Angel/p/8862649.html u ...