题目链接:https://cn.vjudge.net/problem/HDU-3065

题意

跟上一道题是几乎一模一样,这次是统计关键词的出现次数

一个相当坑的地方,注意多组样例

思路

套模版

改insert方法,这次我们指定每个关键词的idx

改query方法,统计value_counter(话说最近几天在用pandas,value_counts确实方便)

提交过程

WA*n 注意多组样例
WA 注意用128大小的分支,用26个同时判断待匹配串的话会WA?
AC

代码

  1. #include <map>
  2. #include <queue>
  3. #include <cstdio>
  4. #include <string>
  5. #include <cstring>
  6. using namespace std;
  7. const int maxn=1000+20, maxw=50+20, maxl=2000000+20;
  8. const int ACSize=maxn*maxw, maxitem=128;
  9. char word[maxw], line[maxl];
  10. map<int, string> tostr;
  11. struct ACauto{
  12. int next[ACSize][maxitem], fail[ACSize], cnt[ACSize];
  13. int root, total;
  14. int newnode(void){
  15. for(int pos=0; pos<maxitem; pos++)
  16. next[total][pos]=-1;
  17. cnt[total]=0;
  18. return total++;
  19. }
  20. void init(void){
  21. total=0;
  22. root=newnode();
  23. }
  24. int getPos(char ch){
  25. return ch;
  26. }
  27. void insert(char buf[], int idx){
  28. int now=root;
  29. for(int i=0; buf[i]; i++){
  30. int pos=getPos(buf[i]);
  31. if(next[now][pos]==-1)
  32. next[now][pos]=newnode();
  33. now=next[now][pos];
  34. }
  35. cnt[now]=idx; //++itemCounter;
  36. }
  37. void build(void){
  38. queue<int> que;
  39. fail[root]=root;
  40. for(int i=0; i<maxitem; i++)
  41. if(next[root][i]==-1)
  42. next[root][i]=root;
  43. else{
  44. fail[next[root][i]]=root;
  45. que.push(next[root][i]);
  46. }
  47. while(!que.empty()){
  48. int now=que.front(); que.pop();
  49. for(int pos=0; pos<maxitem; pos++)
  50. if(next[now][pos]==-1)
  51. next[now][pos]=next[fail[now]][pos];
  52. else{
  53. fail[next[now][pos]]=next[fail[now]][pos];
  54. que.push(next[now][pos]);
  55. }
  56. }
  57. }
  58. void query(char buf[], int counter[]){
  59. int now=root;
  60. for(int i=0; buf[i]; i++){
  61. int pos=getPos(buf[i]);
  62. // if (pos<0 || pos>=maxitem){pos=root; continue;}
  63. now=next[now][pos];
  64. for (int tmp=now; tmp!=root; tmp=fail[tmp]) if (cnt[tmp])
  65. counter[cnt[tmp]]++;
  66. }
  67. }
  68. }AC;
  69. int main(void){
  70. int m, n;
  71. while (scanf("%d", &n)==1 &&n){
  72. AC.init();
  73. for (int i=1; i<=n; i++){
  74. scanf("%s", word);
  75. AC.insert(word, i);
  76. tostr[i]=string(word);
  77. }AC.build();
  78. int counter[maxn]={0};
  79. scanf("%s", line);
  80. AC.query(line, counter);
  81. for (int i=1; i<=n; i++) if (counter[i])
  82. printf("%s: %d\n", tostr[i].c_str(), counter[i]);
  83. }
  84. return 0;
  85. }
Time Memory Length Lang Submitted
234ms 18004kB 2417 C++ 2018-08-02 17:39:24

HDU-3065 病毒侵袭持续中 字符串问题 AC自动机的更多相关文章

  1. HDU 3065 病毒侵袭持续中

    HDU 3065 病毒侵袭持续中 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  2. hdu 3065病毒侵袭持续中

    病毒侵袭持续中 http://acm.hdu.edu.cn/showproblem.php?pid=3065 Time Limit: 2000/1000 MS (Java/Others)    Mem ...

  3. HDU 3065 病毒侵袭持续中(AC自己主动机)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=3065 Problem Description 小t非常感谢大家帮忙攻克了他的上一个问题.然而病毒侵袭 ...

  4. HDU 3065 病毒侵袭持续中 (AC自动机)

    题目链接 Problem Description 小t非常感谢大家帮忙解决了他的上一个问题.然而病毒侵袭持续中.在小t的不懈努力下,他发现了网路中的"万恶之源".这是一个庞大的病毒 ...

  5. HDU 3065 病毒侵袭持续中 (模板题)

    病毒侵袭持续中 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  6. hdu 3065 病毒侵袭持续中【AC自动机】

    <题目链接> 题目大意: 小t非常感谢大家帮忙解决了他的上一个问题.然而病毒侵袭持续中.在小t的不懈努力下,他发现了网路中的“万恶之源”.这是一个庞大的病毒网站,他有着好多好多的病毒,但是 ...

  7. hdu 3065病毒侵袭持续中(ac自动机)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=3065 中文题题意不解释了. 依旧稍微改一下ac自动机模版就能过了.还有一个坑点!是多组数据!!! #i ...

  8. HDU 3065 病毒侵袭持续中(AC自动机)

    这题数据太水,一开始没有加上Get的方法也能AC..话说AC自动机中一定要注意加上Get的方法!(不然,同一个后缀的其他单词就没被算上了.) 代码如下: #include <stdio.h> ...

  9. HDU 3065 病毒侵袭持续中(AC自动机(每个模式串出现次数))

    http://acm.hdu.edu.cn/showproblem.php?pid=3065 题意:求每个模式串出现的次数. 思路: 不难,把模板修改一下即可. #include<iostrea ...

随机推荐

  1. JavaScript中的线程与进程

    定义: 线程分为:单线程和多线程 单线程:一个正在运行的程序(即进行)至少有一个线程,这个线程叫做主线程,只有一个主线程的程序叫做单线程程序,主线程负责执行所有代码的执行(UI展现及刷新.网络请求.本 ...

  2. epoll的边缘触发与水平触发

    epoll的边缘触发与水平触发 Tcp连接是双向的,内核为每个socket维护两个缓冲区,读缓冲区与写缓冲区,内核会一个关注这两个缓冲区,当采用水平触发时,对于写缓冲区而言,如果有多余空间可写,对于读 ...

  3. jq——css类

    1  addClass(classname) 添加类 <script type="text/javascript"> $("input").clic ...

  4. loging模块

    logging模块 什么是logging模块 logging模块是python提供的用于记录日志的模块 为什么需要logging 我们完全可以自己打开文件然后,日志写进去,但是这些操作重复且没有任何技 ...

  5. 密信(MeSince),将取代传统电子邮件

    电子邮件发展至今已经有几十年的历史,但仍然是最重要的现代互联网应用之一.在全球范围内,每小时发送的非垃圾邮件数量超过30亿封,从工作场景的使用到个人生活,电子邮件都扮演着不可或缺的角色.但是由于明文电 ...

  6. Multipartfile与File类型相互转换

    特殊情况下需要做转换 1.M转F File file = new File(path); FileUtils.copyInputStreamToFile(multipartFile.getInputS ...

  7. js获取路径参数对象

    /** * 获取页面路径参数值 */ function getParams(key) { var result = {}; var paramStr = encodeURI(window.docume ...

  8. mysql数据实时同步到Elasticsearch

    业务需要把mysql的数据实时同步到ES,实现低延迟的检索到ES中的数据或者进行其它数据分析处理.本文给出以同步mysql binlog的方式实时同步数据到ES的思路, 实践并验证该方式的可行性,以供 ...

  9. asp.net-DirectoryEntry基本操作入门

    第一个实例代码 DirectorySearcher命名空間 (System.DirectoryServices;) DirectorySearcher search = new DirectorySe ...

  10. 工具-WIN7-内存占用过高解决办法

    我的WIN7内存竟然吃到了7.6G,太不可思意了 第一步 看看网上的解决办法 http://jingyan.baidu.com/article/870c6fc31060eab03fe4beee.htm ...