题目背景

XS中学化学竞赛组教练是一个酷爱炉石的人。

他会一边搓炉石一边点名以至于有一天他连续点到了某个同学两次,然后正好被路过的校长发现了然后就是一顿欧拉欧拉欧拉(详情请见已结束比赛CON900)。

题目描述

这之后校长任命你为特派探员,每天记录他的点名。校长会提供化学竞赛学生的人数和名单,而你需要告诉校长他有没有点错名。(为什么不直接不让他玩炉石。)

输入输出格式

输入格式:

第一行一个整数 n,表示班上人数。接下来 n 行,每行一个字符串表示其名字(互不相同,且只含小写字母,长度不超过 50)。第 n+2 行一个整数 m,表示教练报的名字。接下来 m 行,每行一个字符串表示教练报的名字(只含小写字母,且长度不超过 50)。

输出格式:

对于每个教练报的名字,输出一行。如果该名字正确且是第一次出现,输出“OK”,如果该名字错误,输出“WRONG”,如果该名字正确但不是第一次出现,输出“REPEAT”。(均不加引号)

输入输出样例

输入样例#1:

  1. 5
  2. a
  3. b
  4. c
  5. ad
  6. acd
  7. 3
  8. a
  9. a
  10. e
输出样例#1:

  1. OK
  2. REPEAT
  3. WRONG

说明

对于 40%的数据,n≤1000,m≤2000;

对于 70%的数据,n≤10000,m≤20000;

对于 100%的数据, n≤10000,m≤100000。

题解:

依旧是tire树裸题

但表示RE了无数次之后,终于意识到一定要把数组开到足够大(在题目允许的情况下)

小技巧:判断重复查询时,对单词结尾进行一个小改动(详见代码)

  1. 1 #include<iostream>
  2. 2 #include<cstdio>
  3. 3 #include<algorithm>
  4. 4 #include<cmath>
  5. 5 #define ll long long
  6. 6 #include<cstring>
  7. 7 #include<string>
  8. 8 #define DB double
  9. 9 using namespace std;
  10. 10 char s[600000];
  11. 11 int t[900000][30];
  12. 12 int tot,n,Q;
  13. 13 int v[9000000],fg;
  14. 14 void ins()
  15. 15 {
  16. 16 int l=strlen(s+1);
  17. 17 int now=0;
  18. 18 for(int i=1;i<=l;++i)
  19. 19 {
  20. 20 int k=s[i]-'a'+1;
  21. 21 if(!t[now][k]) t[now][k]=++tot;
  22. 22 now=t[now][k];
  23. 23 }
  24. 24 v[now]=1;
  25. 25 }
  26. 26 int query()
  27. 27 {
  28. 28 int cnt=0,now=0,l=strlen(s+1);
  29. 29 for(int i=1;i<=l;++i)
  30. 30 {
  31. 31 int k=s[i]-'a'+1;
  32. 32 if(t[now][k]) now=t[now][k];
  33. 33 else return 0;
  34. 34 }
  35. 35 if(!v[now]) return 0;
  36. 36 if(v[now]==1)
  37. 37 {
  38. 38 v[now]++;
  39. 39 return 1;
  40. 40 }
  41. 41 return 2;
  42. 42 }
  43. 43 int main()
  44. 44 {
  45. 45 scanf("%d",&n);
  46. 46 for(int i=1;i<=n;++i)
  47. 47 {
  48. 48 scanf("%s",s+1);
  49. 49 ins();
  50. 50 }
  51. 51 scanf("%d",&Q);
  52. 52 while(Q--)
  53. 53 {
  54. 54 scanf("%s",s+1);
  55. 55 fg=query();
  56. 56 if(fg==0) puts("WRONG");
  57. 57 if(fg==1) puts("OK");
  58. 58 if(fg==2) puts("REPEAT");
  59. 59 }
  60. 60 return 0;
  61. 61 }

疾风怒雨,禽鸟戚戚;霁日光风,草木欣欣。

Tire树模板-于是他错误的点名开始了的更多相关文章

  1. KMP+Tire树(模板)

    \(\color{Red}{KMP板子}\) #include <bits/stdc++.h> using namespace std; const int maxn=1e6+9; int ...

  2. Tire树总结(模板+例题)

    题目来自<算法竞赛设计指南> Tire树是一种可以快速查找字符串的数据结构 模板 #include<cstdio> #include<algorithm> #inc ...

  3. LUOGU P2580 于是他错误的点名开始了(trie树)

    传送门 解题思路 trie树模板

  4. luogu P2580 于是他错误的点名开始了

    luogu  P2580 于是他错误的点名开始了 https://www.luogu.org/problem/show?pid=2580 题目背景 XS中学化学竞赛组教练是一个酷爱炉石的人. 他会一边 ...

  5. 于是他错误的点名开始了 [Trie]

    于是他错误的点名开始了 题目背景 XS中学化学竞赛组教练是一个酷爱炉石的人. 他会一边搓炉石一边点名以至于有一天他连续点到了某个同学两次,然后正好被路过的校长发现了然后就是一顿欧拉欧拉欧拉(详情请见已 ...

  6. hdu1754 I hate it线段树模板 区间最值查询

    题目链接:这道题是线段树,树状数组最基础的问题 两种分类方式:按照更新对象和查询对象 单点更新,区间查询; 区间更新,单点查询; 按照整体维护的对象: 维护前缀和; 维护区间最值. 线段树模板代码 # ...

  7. Tire树简介

    又称单词查找树,Trie树,是一种树形结构,是一种哈希树的变种. 典型应用:用于统计,排序和保存大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计. 它的优点是:利用字符串的公共 ...

  8. Tire树(字典树)

    from:https://www.cnblogs.com/justinh/p/7716421.html Trie,又经常叫前缀树,字典树等等.它有很多变种,如后缀树,Radix Tree/Trie,P ...

  9. HDU3948 & 回文树模板

    Description: 求本质不同回文子串的个数 Solution: 回文树模板,学一学贴一贴啊... Code: /*================================= # Cre ...

随机推荐

  1. centos7 中如何查看、打开、关闭防火墙。

    首先是看centos7的防火墙的状态,查看的命令为: sudo systemctl status firewalld. 查看后,看到active(running)就意味着防火墙打开了, 如果想关闭防火 ...

  2. array_chunk的用法和php操作大数据

    一.array_chunk() 函数 二.php操作大数据 1.在操作大数量数据与数据库交互时,比如插入大量数据,db就会报错,这时可以把原本的数据用array_chunk分隔成几个数组块,再循环插入 ...

  3. Ubuntu下软件打开时状态图标与原始图标不重合问题解决

    问题描述 如下图书所示,pycharm打开时,运行的pycharm图标与原始的在收藏夹中的图标不重合.而其他软件不会这样,运行软件的图标与原始图标会重合, 解决办法 把鼠标悬浮在打开的pycharm上 ...

  4. Nginx + Tomcat动静分离 (转)

    什么是动静分离 为了提高网站的响应速度,减轻程序服务器(Tomcat,Jboss等)的负载,对于静态资源比如图片,js,css等文件,我们可以在反向代理服务器中进行缓存,这样浏览器在请求一个静态资源时 ...

  5. PHP post调接口代码

    PHP post调接口代码 /** * $url:接口地址 * $data:数组参数 **/ function postData($url, $data) { $ch = curl_init (); ...

  6. PHP foreach 引用 &

    以前用foreach,总喜欢在第二次遍历时改变value的拼写,比如 $x = array("a", "b", "c"); foreach ...

  7. drop与truncate与delete的区别与联系

    在mysql和oracle数据库中delete与truncate都是可以用来对数据进行删除操作,但是二者又有些不同. 主要有以下几个区别: 区别一: 根据sql语言分类来说,delete属于DML语言 ...

  8. css阴影——box-shadow

    1.语法 box-shadow: h-shadow v-shadow blur spread color inset;      box-shadow: 水平阴影  垂直阴影 模糊距离 阴影大小 阴影 ...

  9. 关于strcpy的安全函数的选择

    1)如果整个程序,在进行字符拷贝时,这个拷贝字符串的完整性,不影响整个程 序的运行,可以让其截取一部分字符串,程序继续执行.那么我们就可以选择安全 函数:strncpy_s 2)如果在进行字符串拷贝时 ...

  10. java数据结构复习02

    1.递归问题 1.1汉诺塔问题(递归) 问题描述三个柱子,起初有若干个按大小关系顺序安放的盘子,需要全部移动到另外一个柱子上.移动规则:在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘.移动 ...