洛谷 - P2444 - 病毒 - AC自动机
https://www.luogu.org/problemnew/show/P2444
有点恶心,不太明白fail的意义。
#include<bits/stdc++.h>
using namespace std;
#define ll long long struct Trie{
int nex[][],fail[],End[];
int root,L;
int newnode(){
/*for(int i=0;i<26;i++)
nex[L][i]=-1;*/
End[L++]=;
return L-;
} int cnt;
void init(){
L=;
cnt=;
memset(nex,-,sizeof(nex));
root=newnode();
} void insert(char buf[]){
int len=strlen(buf);
int now=root;
for(int i=;i<len;i++){
int &t=nex[now][buf[i]-''];
if(t==-)
t=newnode();
now=t;
}
End[now]++;
cnt++;
} void build(){
queue<int>Q;
fail[root]=root;
for(int i=;i<;i++){
if(nex[root][i]==-){
nex[root][i]=root;
//根节点没有对应的分支,还是必须回到根节点开始匹配
}
else{
//根节点的后继失配,先假定回到根节点匹配
fail[nex[root][i]]=root;
Q.push(nex[root][i]);
}
}
while(!Q.empty()){
int now=Q.front();
Q.pop();
for(int i=;i<;i++)
if(nex[now][i]==-){
//某个节点没有这个对应的分支,它失配了,沿着失配边去到最近的有这个分支的边?
nex[now][i]=nex[fail[now]][i];
}
else{
fail[nex[now][i]]=nex[fail[now]][i];
Q.push(nex[now][i]);
//如果这个节点的fail指针指向的点是End,那么因为这个节点蕴含他的fail节点,所以他也是End
End[now]|=End[fail[now]];
}
}
} /*int query(char buf[]){
int len=strlen(buf);
int now=root;
int res=0;
for(int i=0;i<len;i++){
now=nex[now][buf[i]-'0'];
int temp=now;
while(temp!=root&&End[temp]!=-1){
res+=End[temp];
End[temp]=-1;
temp=fail[temp];
}
//if(res==cnt)
//return res;
}
return res;
}*/ int vis[];
int instack[];
int find_circle(){
memset(vis,,sizeof(vis));
memset(vis,,sizeof(instack));
return dfs(root);
} int dfs(int id){
instack[id]=;
vis[id]=;
for(int i=;i<;i++){
if(instack[nex[id][i]]){
//该节点的下一条边在dfs栈中,是反向边
printf("TAK\n");
exit();
}
if(vis[nex[id][i]]==){
//不访问已经到过的表亲,表亲不可能成环
if(End[nex[id][i]]==){
//下一个点不是病毒
dfs(nex[id][i]);
}
}
}
instack[id]=;
return ;
} }; char buf[]; Trie ac; int n;
void solve(){
while(~scanf("%d",&n)){
if(n==)
break;
ac.init(); for(int i=;i<n;i++){
scanf("%s",buf);
ac.insert(buf);
}
ac.build();
//scanf("%s",buf); if(ac.find_circle()==){
cout<<"NIE"<<endl;
}
}
} int main(){
#ifdef Yinku
freopen("Yinku.in","r",stdin);
//freopen("Yinku.out","w",stdout);
#endif // Yinku
solve();
}
洛谷 - P2444 - 病毒 - AC自动机的更多相关文章
- 洛谷P2444 病毒【AC自动机】
题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已经找出了所有的病毒代码段,试问,是否 ...
- 洛谷P2444 病毒 [POI2000] AC自动机
正解:AC自动机 解题报告: 传送门! 首先看到这种题目二话不说先把trie树和fail指针建立起来 然后就想鸭,如果我们想让模式串和文本串尽量不能匹配,就要想办法让它跳fail指针,而不是继续往下走 ...
- 洛谷 - P3966 - 单词 - AC自动机
https://www.luogu.org/problemnew/show/P3966 因为文本串就是字典本身,所以这个和平时的AC自动机不太一样.平时的query要沿着fail树把子树的出现次数依次 ...
- 洛谷P3808 & P3796 AC自动机模板
题目:P3808:https://www.luogu.org/problemnew/show/P3808 P3796:https://www.luogu.org/problemnew/show/P37 ...
- 洛谷.3121.审查(AC自动机 链表)
题目链接 //删掉一个单词需要前移一段位置,用链表维护就好了 复杂度O(sum(len)) #include <cstdio> #include <cstring> #defi ...
- 洛谷P2444 [POI2000]病毒(AC自动机,DFS求环)
洛谷题目传送门 AC自动机入门--yyb巨佬的博客 AC自动机入手经典好题(虽然年代久远) 有了fail指针,trie树就不是原来的树型结构了,我们可以把它叫做trie图,由父节点向子节点连的边和fa ...
- 【洛谷 P2444】 [POI2000]病毒(AC自动机)
题目链接 这么多字符串,肯定是自动机啦. 先建出AC自动机,然后怎么表示一个安全代码没有病毒代码呢? 就是存在一条路径不经过有病毒代码段结尾的节点呗. 所以呢?有环啊!dfs一下救星了. #inclu ...
- 【洛谷】P2444 [POI2000]病毒——AC自动机
题目链接 题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已经找出了所有的病毒代码段, ...
- [洛谷P2444] [POI2000]病毒
洛谷题目链接:[POI2000]病毒 题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会 ...
随机推荐
- postgresql 导出建表语句的方法-类似describe table
https://www.youtube.com/watch?v=PMfcsYzj-9M 这个视频不错, The Definitive Guide to Object-Oriented JavaScr ...
- PAT 1003 Sharing (25)
题目描写叙述 To store English words, one method is to use linked lists and store a word letter by letter. ...
- 忘掉VNC/RDP,拿起手中的MobaXterm轻松上手远程桌面
前言 原创文章,转载引用务必注明链接. 这期属于番外篇,随便写写.吐槽一下自己,关于"减少eMMC擦写,延长NAND寿命提升性能"的坑还没填完,都不好愉快地写点轻松的小项目灌水了. ...
- HTML5已定稿:将彻底颠覆原生应用
2007年W3C(万维网联盟)立项HTML5,直至2014年10月底.这个长达八年的规范最终正式封稿. 过去这些年.HTML5颠覆了PC互联网的格局,优化了移动互联网的体验,接下来.HTML5将颠覆原 ...
- Log4cpp 使用手册
参考资料: log4cpp 配置 与 使用http://www.cnblogs.com/welkinwalker/archive/2011/06/23/2088197.html 便利的开发工具-log ...
- FastDFS的配置、部署与API使用解读(2)以字节方式上传文件的客户端代码(转)
本文来自 诗商·柳惊鸿 Poechant CSDN博客,转载请注明源地址:FastDFS的配置.部署与API使用解读(2)上传文件到FastDFS分布式文件系统的客户端代码 在阅读本文之前,请您先通过 ...
- CAS原子操作实现无锁及性能分析
CAS原子操作实现无锁及性能分析 Author:Echo Chen(陈斌) Email:chenb19870707@gmail.com Blog:Blog.csdn.net/chen19870707 ...
- C++函数模板例子
//C++函数模板实例 #include <iostream>template <class Any>void Swap(Any &a, Any &b); in ...
- LeetCode(26)题解:Remove Duplicates from Sorted Array
https://leetcode.com/problems/remove-duplicates-from-sorted-array/ Given a sorted array, remove the ...
- 第一讲:使用html5——canvas绘制奥运五环
<html> <head> <title>初识canvas</title> </head> <body> <canvas ...