HDU 2896 病毒侵袭 (AC自己主动机)
pid=2896">http://acm.hdu.edu.cn/showproblem.php?pid=2896
病毒侵袭
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 11796 Accepted Submission(s): 3067
。。。在这种时刻,人们却异常兴奋——我们能在有生之年看到500年一遇的世界奇观,那是多么幸福的事儿啊~~
但网路上总有那么些站点,開始借着民众的好奇心。打着介绍日食的旗号,大肆传播病毒。
小t不幸成为受害者之中的一个。
小t如此生气,他决定要把世界上全部带病毒的站点都找出来。
当然,谁都知道这是不可能的。小t却执意要完毕这不能的任务。他说:“子子孙孙无穷匮也。”(愚公后继有人了)。
万事开头难,小t收集了好多病毒的特征码,又收集了一批诡异站点的源代码,他想知道这些站点中哪些是有病毒的,又是带了如何的病毒呢?顺便还想知道他究竟收集了多少带病毒的站点。这时候他却不知道何从下手了。
所以想请大家帮帮忙。
小t又是个急性子哦。所以解决这个问题越快越好哦~~
接下来N行。每行表示一个病毒特征码。特征码字符串长度在20—200之间。
每一个病毒都有一个编号,依此为1—N。
不同编号的病毒特征码不会同样。
在这之后一行,有一个整数M(1<=M<=1000),表示站点数。
接下来M行,每行表示一个站点源代码。源代码字符串长度在7000—10000之间。
每一个站点都有一个编号。依此为1—M。
以上字符串中字符都是ASCII码可见字符(不包含回车)。
web 站点编号: 病毒编号 病毒编号 …
冒号后有一个空格,病毒编号按从小到大排列,两个病毒编号之间用一个空格隔开。假设一个站点包括病毒,病毒数不会超过3个。
最后一行输出统计信息。例如以下格式
total: 带病毒站点数
冒号后有一个空格。
3
aaa
bbb
ccc
2
aaabbbccc
bbaacc
web 1: 1 2 3
total: 1
题意:
自己看题。
分析:
简单粗暴的AC自己主动机模板题。
/*
*
* Author : fcbruce
*
* Time : Sat 04 Oct 2014 07:39:54 PM CST
*
*/
#include <cstdio>
#include <iostream>
#include <sstream>
#include <cstdlib>
#include <algorithm>
#include <ctime>
#include <cctype>
#include <cmath>
#include <string>
#include <cstring>
#include <stack>
#include <queue>
#include <list>
#include <vector>
#include <map>
#include <set>
#define sqr(x) ((x)*(x))
#define LL long long
#define itn int
#define INF 0x3f3f3f3f
#define PI 3.1415926535897932384626
#define eps 1e-10 #ifdef _WIN32
#define lld "%I64d"
#else
#define lld "%lld"
#endif #define maxm 128
#define maxn 100007 using namespace std; bool found[507];
char T[10007];
char P[233];
int q[maxn<<2]; struct ACauto
{
int ch[maxn][maxm];
int val[maxn];
int nex[maxn];
int last[maxn];
int cnt;
int sz; ACauto()
{
sz=1;
val[0]=0;
memset(ch[0],0,sizeof ch[0]);
} void clear()
{
sz=1;
val[0]=0;
memset(ch[0],0,sizeof ch[0]);
} int idx(const char ch)
{
return ch-'\0';
} void insert(const char *s,int v=1)
{
int u=0;
for (int i=0;s[i]!='\0';i++)
{
int c=idx(s[i]);
if (ch[u][c]==0)
{
val[sz]=0;
memset(ch[sz],0,sizeof ch[sz]);
ch[u][c]=sz++;
}
u=ch[u][c];
}
val[u]=v;
} void get_fail()
{
int f=0,r=-1;
nex[0]=0;
last[0]=0;
for (int c=0;c<maxm;c++)
{
int u=ch[0][c];
if (u!=0)
{
nex[u]=0;
q[++r]=u;
last[u]=0;
}
} while (f<=r)
{
int x=q[f++];
for (int c=0;c<maxm;c++)
{
int u=ch[x][c];
if (u==0) continue;
q[++r]=u;
int j=nex[x];
while (j>0 && ch[j][c]==0) j=nex[j];
nex[u]=ch[j][c];
last[u]=val[nex[u]]>0? nex[u]:last[nex[u]];
}
}
} void calc(int j)
{
if (j!=0)
{
cnt++;
found[val[j]]=true;
calc(last[j]);
}
} void find(const char *T)
{
cnt=0;
memset(found,0,sizeof found); for (int i=0,j=0;T[i]!='\0';i++)
{
int c=idx(T[i]);
while (j>0 && ch[j][c]==0) j=nex[j];
j=ch[j][c];
if (val[j]!=0)
calc(j);
else if (last[j]!=0)
calc(last[j]);
}
}
}acauto; int main()
{
#ifdef FCBRUCE
freopen("/home/fcbruce/code/t","r",stdin);
#endif // FCBRUCE int n; while (scanf("%d",&n)==1)
{
acauto.clear(); for (int i=1;i<=n;i++)
{
scanf("%s",P);
acauto.insert(P,i);
} acauto.get_fail(); int m;
scanf("%d",&m); int cnt=0; for (int i=1;i<=m;i++)
{
scanf("%s",T);
acauto.find(T); if (acauto.cnt>0)
{
cnt++;
printf("web %d:",i);
for (int j=1;j<=n;j++)
if (found[j])
printf(" %d",j);
putchar('\n');
}
} printf("total: %d\n",cnt);
} return 0;
}
HDU 2896 病毒侵袭 (AC自己主动机)的更多相关文章
- HDU 2896 病毒侵袭 AC自己主动机题解
本题是在text里面查找key word的增强版.由于这里有多个text. 那么就不能够简单把Trie的叶子标志记录改动成-1进行加速了,能够使用其它技术.我直接使用个vis数组记录已经訪问过的节点, ...
- hdu 2896 病毒侵袭 ac自动机
/* hdu 2896 病毒侵袭 ac自动机 从题意得知,模式串中没有重复的串出现,所以结构体中可以将last[](后缀链接)数组去掉 last[]数组主要是记录具有相同后缀模式串的末尾节点编号 .本 ...
- hdu 2896 病毒侵袭 AC自动机(查找包含哪些子串)
病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- hdu 2896 病毒侵袭 AC自动机 基础题
病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- POJ 3691 & HDU 2457 DNA repair (AC自己主动机,DP)
http://poj.org/problem?id=3691 http://acm.hdu.edu.cn/showproblem.php?pid=2457 DNA repair Time Limit: ...
- HDU 2825 Wireless Password (AC自己主动机,DP)
pid=2825">http://acm.hdu.edu.cn/showproblem.php? pid=2825 Wireless Password Time Limit: 2000 ...
- hdu 2222 Keywords Search ac自己主动机
点击打开链接题目链接 Keywords Search Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Ja ...
- HDU - 2825 Wireless Password(AC自己主动机+DP)
Description Liyuan lives in a old apartment. One day, he suddenly found that there was a wireless ne ...
- HDU 2222 Keywords Search AC自己主动机入门题
单词统计的题目,给出一些单词,统计有多少单词在一个文本中出现,最经典的入门题了. AC自己主动机的基础: 1 Trie. 以这个数据结构为基础的,只是添加一个fail指针和构造fail的函数 2 KM ...
随机推荐
- <Spring Cloud>入门四 Feign
1.Feign 之前使用的是Ribbon+RestTemplate调用,通过的是微服务的名字进行调用,实现负载均衡 但是为了满足接口编程,提供了Feign 2.实现 2.1引入坐标 在 ms-comm ...
- 15. PARTITIONS
15. PARTITIONS PARTITIONS表提供有关表分区的信息. 此表中的每一行对应于分区表的单个分区或子分区. 有关分区表的更多信息,请参见分区. PARTITIONS表有以下列: TAB ...
- Linux硬盘的检测--smartctl详细介绍
概述 随着硬盘容量.速度的快速发展,硬盘的可靠性问题越来越重要,今天的单块硬盘存储容量可轻松达到1TB,硬盘损坏带来的影响非常巨大.不同的文件系统(xfs,reiserfs,ext3)都有自己的检测 ...
- [MVC][Shopping]Copy Will's Code
数据模型规划(Models) //DisplayNameAttribute 指定属性的显示名称 [DisplayName("商品类别")] //DisplayColumnAttri ...
- 【7.1.1】ELK日志系统单体搭建
ELK是什么? 一般来说,为了提高服务可用性,服务器需要部署多个实例,每个实例都是负载均衡转发的后的,如果还用老办法登录服务器去tail -f xxx.log,有很大可能错误日志未出现在当前服务器中, ...
- Haproxy配置文件详解
#/usr/local/sbin/haproxy -f /etc/haproxy/haproxy.cfg -st `cat /var/run/haproxy.pid` ################ ...
- luogu3960 列队
参考这篇 #include <iostream> #include <cstdio> #include <vector> using namespace std; ...
- windows 2008、2012防火墙添加入站规则教程(端口例外)
windows2008.2012的设置方法基本一样,以下是以windows2008为例做添加80端口的步骤. 1.依次点“控制面板”→“系统和安全”→“windows防火墙”→“高级设置”,打开“高级 ...
- CodeForces - 320B Ping-Pong (Easy Version)
题目最开始 完全不懂 配合案例也看不懂-_- 总之就是用传递性 问能否从a区间到b区间 dfs(x,y) 走遍与第x区间所有的 联通区间 最后检验 第y区是否被访问过 是一道搜索好题 搜索还需加强 # ...
- [NOIP2002] 普及组
产生数 预处理出一个数能变成多少种数,然后遍历原串的每一位,累乘方案数即可. 需要用到高精度. /*By SilverN*/ #include<iostream> #include< ...