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 ...
随机推荐
- PyTorch的十七个损失函数
本文截取自<PyTorch 模型训练实用教程>,获取全文pdf请点击: tensor-yu/PyTorch_Tutorialgithub.com 版权声明:本文为博主原创文章,转载请附上 ...
- 出现了错误。详细消息: 3 uncommitted changes would be overwritten by merge
merge manual中有一条警告: 出现了错误.详细消息: 3 uncommitted changes would be overwritten by merge 有未提交修改情况下,不要执行me ...
- 【JavaEE-面试总结】(未完,待续···)
目录: 一.Java基础 二.JavaEE基础 三.JavaEE进阶 四.数据库 五.数据结构&算法 六.高级(服务器) 一.Java基础 1.1 面向对象(封装.继承.多态) 访问权限修饰符 ...
- ES5的数组方法
参考:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array Array.prot ...
- vue 运行时 + 编译器 vs. 只包含运行时
https://cn.vuejs.org/v2/guide/installation.html#运行时-编译器-vs-只包含运行时 文档中的这个地方,说的不清楚 If you need to comp ...
- 谈一谈flex布局使用中碰到的一些问题
起因 工作以后由于大量使用到了flex布局而碰到了一些尚不清楚的问题,以及一些有意思的特性,在此写篇博客记录一下. flex三个值的含义 众所周知,flex布局所有的属性有两种:一种作用在弹性容器(F ...
- JAVA:ssm框架搭建
文章来源:http://www.cnblogs.com/hello-tl/p/8328071.html 环境简介 : jdk1.7.0_25/jdk1.8.0_31 tomcat-7.0.81 m ...
- 《算法导论》 — Chapter 7 快速排序
序 快速排序(QuickSort)也是一种排序算法,对包含n个数组的输入数组,最坏情况运行时间为O(n^2).虽然这个最坏情况运行时间比较差,但是快速排序通常是用于排序的最佳实用选择,这是因为其平均性 ...
- 【51nod 1791】 合法括号子段
有一个括号序列,现在要计算一下它有多少非空子段是合法括号序列. 合法括号序列的定义是: 1.空序列是合法括号序列. 2.如果S是合法括号序列,那么(S)是合法括号序列. 3.如果A和B都是合法括号序列 ...
- selenium之文件上传
文件上传是所有UI自动化测试都要面对的一个头疼问题,今天博主在这里给大家分享下自己处理文件上传的经验,希望能够帮助到广大被文件上传坑住的seleniumer. 首先,我们要区分出上传按钮的种类,大体上 ...