Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 10504    Accepted Submission(s): 3701

Problem Description
小t非常感谢大家帮忙解决了他的上一个问题。然而病毒侵袭持续中。在小t的不懈努力下,他发现了网路中的“万恶之源”。这是一个庞大的病毒网站,他有着好多好多的病毒,但是这个网站包含的病毒很奇怪,这些病毒的特征码很短,而且只包含“英文大写字符”。当然小t好想好想为民除害,但是小t从来不打没有准备的战争。知己知彼,百战不殆,小t首先要做的是知道这个病毒网站特征:包含多少不同的病毒,每种病毒出现了多少次。大家能再帮帮他吗?
Input
第一行,一个整数N(1<=N<=1000),表示病毒特征码的个数。
接下来N行,每行表示一个病毒特征码,特征码字符串长度在1—50之间,并且只包含“英文大写字符”。任意两个病毒特征码,不会完全相同。
在这之后一行,表示“万恶之源”网站源码,源码字符串长度在2000000之内。字符串中字符都是ASCII码可见字符(不包括回车)。
Output
按以下格式每行一个,输出每个病毒出现次数。未出现的病毒不需要输出。
病毒特征码: 出现次数
冒号后有一个空格,按病毒特征码的输入顺序进行输出。
Sample Input
3
AA
BB
CC
ooxxCC%dAAAoen....END
Sample Output
AA: 2
CC: 1
 
Hint

Hit:
题目描述中没有被提及的所有情况都应该进行考虑。比如两个病毒特征码可能有相互包含或者有重叠的特征码段。
计数策略也可一定程度上从Sample中推测。

 
【分析】
  做了BZOJ2434,这题就显得很简单了。反正我的做法跟上一题其实差不多,就是先建AC自动机,然后求DFS序,再走一遍目标串,打好标记,最后求一个区间的和即可。不过目测其他慢一点的方法也是可以的。
 
代码如下:
  1. #include<cstdio>
  2. #include<cstdlib>
  3. #include<cstring>
  4. #include<iostream>
  5. #include<algorithm>
  6. #include<queue>
  7. using namespace std;
  8. #define Maxn 100100
  9. #define Maxl 2000010
  10. #define Ml 60
  11. #define Mn 1010
  12.  
  13. char ss[Mn][Ml];
  14. char s[Maxl];
  15. int p[Maxn],c[Maxn];
  16. int n;
  17.  
  18. struct hp
  19. {
  20. int x,y,next;
  21. }qy[Maxn];int al;
  22.  
  23. struct node
  24. {
  25. int son[],cnt,fail;
  26. int num,rt;
  27. }t[Maxn];int tot;
  28.  
  29. int first[Maxn];
  30.  
  31. void ins(int x,int y)
  32. {
  33. qy[++al].x=x;qy[al].y=y;
  34. qy[al].next=first[x];first[x]=al;
  35. }
  36.  
  37. void upd(int x)
  38. {
  39. t[x].cnt=;
  40. memset(t[x].son,,sizeof(t[x].son));
  41. }
  42.  
  43. void read_trie(int x)
  44. {
  45. scanf("%s",ss[x]+);
  46. int len=strlen(ss[x]+);
  47. int now=;
  48. for(int j=;j<=len;j++)
  49. {
  50. int ind=ss[x][j]-'A'+;
  51. if(!t[now].son[ind])
  52. t[now].son[ind]=++tot,upd(tot);
  53. now=t[now].son[ind];
  54. if(j==len) t[now].cnt++,p[x]=now;
  55. }
  56. }
  57.  
  58. queue<int > q;
  59. void build_AC()
  60. {
  61. int i,j,x,y;
  62. while(!q.empty()) q.pop();
  63. q.push();
  64. while(!q.empty())
  65. {
  66. x=q.front();
  67. y=t[x].fail;
  68. for(j=;j<=;j++)
  69. {
  70. if(t[x].son[j])
  71. {
  72. q.push(t[x].son[j]);
  73. t[t[x].son[j]].fail=x?t[y].son[j]:x;
  74. ins(t[t[x].son[j]].fail,t[x].son[j]);
  75. }
  76. else t[x].son[j]=t[y].son[j];
  77. }
  78. q.pop();
  79. }
  80. }
  81.  
  82. void dfs(int x)
  83. {
  84. t[x].num=++al;t[x].rt=t[x].num;
  85. for(int i=first[x];i;i=qy[i].next)
  86. dfs(qy[i].y),t[x].rt=t[qy[i].y].rt;
  87. }
  88.  
  89. void dfs2(int x)
  90. {
  91. scanf("%s",s+);
  92. int len=strlen(s+);
  93. int now=;
  94. for(int j=;j<=len;j++)
  95. {
  96. if(s[j]<'A'||s[j]>'Z') {now=;continue;}
  97. int ind=s[j]-'A'+;
  98. now=t[now].son[ind];
  99. c[t[now].num]++;
  100. }
  101. }
  102.  
  103. void init()
  104. {
  105. memset(first,,sizeof(first));
  106. tot=;upd();
  107. for(int i=;i<=n;i++)
  108. {
  109. read_trie(i);
  110. }
  111. al=;build_AC();al=;
  112. dfs();
  113. memset(c,,sizeof(c));
  114. dfs2();c[]=;
  115. for(int i=;i<=al;i++) c[i]=c[i-]+c[i];
  116. for(int i=;i<=n;i++)
  117. {
  118. int ans=;
  119. ans=c[t[p[i]].rt]-c[t[p[i]].num-];
  120. if(ans!=) printf("%s: %d\n",ss[i]+,ans);
  121. }
  122. }
  123.  
  124. int main()
  125. {
  126. while(scanf("%d",&n)!=EOF)
  127. {
  128. init();
  129. }
  130. return ;
  131. }

[HDU3065]

2016-06-17 13:46:45

【HDU3065】 病毒侵袭持续中(AC自动机)的更多相关文章

  1. hdu3065 病毒侵袭持续中 AC自动机入门题 N(N <= 1000)个长度不大于50的模式串(保证所有的模式串都不相同), 一个长度不大于2000000的待匹配串,求模式串在待匹配串中的出现次数。

    /** 题目:hdu3065 病毒侵袭持续中 链接:http://acm.hdu.edu.cn/showproblem.php?pid=3065 题意:N(N <= 1000)个长度不大于50的 ...

  2. HDU3065 病毒侵袭持续中 —— AC自动机

    题目链接:https://vjudge.net/problem/HDU-3065 病毒侵袭持续中 Time Limit: 2000/1000 MS (Java/Others)    Memory Li ...

  3. hdu----(3065)病毒侵袭持续中(AC自动机)

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

  4. HDU-3065 病毒侵袭持续中 AC自动机又是一板子!

    病毒侵袭持续中 上一题是求出现多少病毒输出病毒序号,而这题输出每个病毒出现的次数.这题有字典树基础都能做出来,把叶子节点用相应的编号标记起来,匹配的时候遍历到叶子节点用一个数组把次数存起来就行了. 有 ...

  5. [hdu3065]病毒侵袭持续中(AC自动机)

    题意:给出多种病毒的号码和特征码,计算在某串中各病毒匹配的次数. 解题关键:AC自动机模板题,多组输入坑人. #include<bits/stdc++.h> using namespace ...

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

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

  7. hdoj 3065 病毒侵袭持续中(AC自动机)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3065 思路分析:问题需要模式匹配多个模式串,需要注意的是模式串会包含和重叠,需要对AC自动机的匹配过 ...

  8. hdu3065 病毒侵袭持续中【AC自动机】

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

  9. hdu3065 病毒侵袭持续中

    题目地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=3065 题目: 病毒侵袭持续中 Time Limit: 2000/1000 MS (Java ...

  10. HDU-3065 病毒侵袭持续中 字符串问题 AC自动机

    题目链接:https://cn.vjudge.net/problem/HDU-3065 题意 跟上一道题是几乎一模一样,这次是统计关键词的出现次数 一个相当坑的地方,注意多组样例 思路 套模版 改in ...

随机推荐

  1. Memcached Java Client with sample program--reference

    In my previous post, I listed down most common telnet commands for memcached with sample execution t ...

  2. ServletContext对象--三大域对象

    Servlet三大域对象的应用 request.session.application(ServletContext) ServletContext是一个全局的储存信息的空间,服务器开始就存在,服务器 ...

  3. Java的浮点数

    为了防止无良网站的爬虫抓取文章,特此标识,转载请注明文章出处.LaplaceDemon/ShiJiaqi. http://www.cnblogs.com/shijiaqi1066/p/5160771. ...

  4. 定位 position

    html结构是fixed包裹relative,relative包裹absolute position:relative;相对定位 a 不影响元素本身的特性 b 不使元素脱离文档流(元素移动之后原始位置 ...

  5. inline-block间隙原因和解决方法(web前端问题)

    申明:IE7无法测试,所以下面说的IE6指IE6和IE7 1,遇到的问题 Normal 0 7.8 磅 0 2 false false false EN-US ZH-CN X-NONE /* Styl ...

  6. html 之前学习响应式的笔记

    响应式的设计,根据用户设备的不同,用户屏幕大小不同,提供不同的网页设计http://mediaqueri.es/PhoneGap 使用2,如何模拟手机设备chome 浏览器 在32以上设备检测用 de ...

  7. (转)Java爬虫,信息抓取的实现

    转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/23272657 今天公司有个需求,需要做一些指定网站查询后的数据的抓取,于是花了点 ...

  8. Android常用错误解决汇总

    一.No active compatible AVD's or devices found. Relaunch this configuration after connecting a device ...

  9. phpMyAdmin教程 之 创建新用户/导入/导出数据库

    盗用了被人的教程. 需要看就点击进去吧.复制过来实在是过意不去 http://www.wpdaxue.com/phpmyadmin-import-export-database.html

  10. 关于基于.net的WEB程序开发所需要的一些技术归纳

    前提: 最近公司里有一个同事,年龄比我大几岁,但是由于是转行来做开发的,许多的关于.net开发技术不是很入行,所以总是会问我一些东西,基于自己以前的一些 经验,总是会愿意给他讲一些总结性的东西,希望他 ...