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 ...
随机推荐
- python解决鸡兔同笼问题
# 这个问题,是我国古代著名趣题之一. # 大约在1500年前,<孙子算经>中就记载了这个有趣的问题. # 书中是这样叙述的:“今有雉兔同笼,上有三十五头,下有九十四足, # 问雉兔各几何 ...
- ixcache的蜜汁突发故障
公元2018年 7月29日 晚上21点整,我司一直正常运行的ixcache线路异常断开. ??? 公司业务包含提供互联网接入服务,所以这个现象将会导致用户上网体验变差,网速变慢,看视频的速度下降等等, ...
- python基础知识06-函数基础和函数参数
函数基础和函数参数 可迭代对象:序列类型 range . 1.函数的定义 def 函数名(参数): pass return 表达式 ,不能是赋值语句.不写默认返回None.用逗号隔开返回一个元组. 函 ...
- 阿里云配置tomcat后不能访问问题
问题:使用阿里云centos 7.2配置好tomcat后,启动时间9分多钟,停在webapps下的manage这里近9分多钟 解决:进入 /usr/local/jdk1.8.0_144/jre/lib ...
- 数据结构实验6:C++实现二叉树类
实验6 学号: 姓名: 专业: 6.1 实验目的 掌握二叉树的动态链表存储结构及表示. 掌握二叉树的三种遍历算法(递归和非递归两类). 运用二叉树三种遍历的方法求解有关问题. 6 ...
- 跟初学者学习IbatisNet第二篇
在上一篇里面我们知道了什么是IbatisNet,并且知道了如何用IbatisNet进行简单的增删改查的操作,在这一篇文章里面我们主要介绍一下IbatisNet操作存储过程. 我们一般把存储过程分为两种 ...
- hrbust-1909理工门外的树,不用线段数,贪心思路~~
理工门外的树 Time Limit: 1000 MS Memory Limit: 32768 K Total Submit: 605(125 users) Total Accepted: 154(11 ...
- Linux(4):文件属性
文件属性: # 重点: 磁盘空间不足 和 软链接与硬链接的区别 查看文件的属性: # ls lhi 文件 [root@NEO ~]# ls -lhi /etc/hosts 130078 -rw-r-- ...
- 修改K/3 Cloud管理中心端口
有时候可能会应为端口号被占用或者数据隔离等等,不会使用K/3 Cloud默认的8000端口,这时候就设计到要修改端口号了,具体步骤如下: 1. 2. 打开{安装目录}\ManageSite\App_D ...
- [Vijos] 河蟹王国
描述 河蟹王国有一位河蟹国王,他的名字叫羊驼.河蟹王国富饶安定,人们和谐相处.有一天,羊驼国王心血来潮,想在一部分人中挑出最和谐的人.于是,羊驼国王将他的子民排成了一列(==!!b汗~好长呀).每个人 ...