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自动机的更多相关文章

  1. 洛谷P2444 病毒【AC自动机】

    题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已经找出了所有的病毒代码段,试问,是否 ...

  2. 洛谷P2444 病毒 [POI2000] AC自动机

    正解:AC自动机 解题报告: 传送门! 首先看到这种题目二话不说先把trie树和fail指针建立起来 然后就想鸭,如果我们想让模式串和文本串尽量不能匹配,就要想办法让它跳fail指针,而不是继续往下走 ...

  3. 洛谷 - P3966 - 单词 - AC自动机

    https://www.luogu.org/problemnew/show/P3966 因为文本串就是字典本身,所以这个和平时的AC自动机不太一样.平时的query要沿着fail树把子树的出现次数依次 ...

  4. 洛谷P3808 & P3796 AC自动机模板

    题目:P3808:https://www.luogu.org/problemnew/show/P3808 P3796:https://www.luogu.org/problemnew/show/P37 ...

  5. 洛谷.3121.审查(AC自动机 链表)

    题目链接 //删掉一个单词需要前移一段位置,用链表维护就好了 复杂度O(sum(len)) #include <cstdio> #include <cstring> #defi ...

  6. 洛谷P2444 [POI2000]病毒(AC自动机,DFS求环)

    洛谷题目传送门 AC自动机入门--yyb巨佬的博客 AC自动机入手经典好题(虽然年代久远) 有了fail指针,trie树就不是原来的树型结构了,我们可以把它叫做trie图,由父节点向子节点连的边和fa ...

  7. 【洛谷 P2444】 [POI2000]病毒(AC自动机)

    题目链接 这么多字符串,肯定是自动机啦. 先建出AC自动机,然后怎么表示一个安全代码没有病毒代码呢? 就是存在一条路径不经过有病毒代码段结尾的节点呗. 所以呢?有环啊!dfs一下救星了. #inclu ...

  8. 【洛谷】P2444 [POI2000]病毒——AC自动机

    题目链接 题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已经找出了所有的病毒代码段, ...

  9. [洛谷P2444] [POI2000]病毒

    洛谷题目链接:[POI2000]病毒 题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会 ...

随机推荐

  1. iOS 小动画

    一.图片旋转 CABasicAnimation* rotationAnimation; rotationAnimation = [CABasicAnimation animationWithKeyPa ...

  2. springmvc学习笔记(18)-json数据交互

    springmvc学习笔记(18)-json数据交互 标签: springmvc springmvc学习笔记18-json数据交互 springmvc进行json交互 环境准备 加入json转换的依赖 ...

  3. WebSocket 和 Socket 的区别

    WebSocket 和 Socket 的区别   英文:TheAlchemist 链接:http://www.jianshu.com/p/59b5594ffbb0 <刨根问底 HTTP 和 We ...

  4. openwrt mt7620 内存大小检测

    单独编译内核: make V=s target/linux/install 相调函数调用流程: init/main.c : start_kernel() -> setup_arch(&c ...

  5. Centos6.5 安装 Oracle11gR2(64位)

    Centos6.5安装 Oracle11gR2(64位) 安装centos6.5 (我的是虚拟机环境) 1.  下载centos6.5的安装包,不解释. 例如以下图: 2.  下载oracle安装包, ...

  6. BingMap地图怎样显示中文

    这是bingMap的js引用 <script type="text/javascript" src="v=7.0&mkt=zh-cn'></sc ...

  7. 基础才是重中之重~用好configSections让配置信息更规范

    对于小型项目来说,配置信息可以通过appSettings进行配置,而如果配置信息太多,appSettings显得有些乱,而且在开发人员调用时,也不够友好,节点名称很容易写错,这时,我们有几种解决方案 ...

  8. Phoenix(SQL On HBase)安装和使用报告

    一.为什么使用Phoenix二.安装Phoenix2.1 兼容问题?2.2 编译CDH版本的Phoenix2.3 安装Phoenix到CDH环境中三.Phoenix的使用3.1 phoenix的4种调 ...

  9. all rows from client_id can grow infinitely compared to a single node when hashing by client_id

    all rows from client_id can grow infinitely compared to a single node when hashing by client_id Re: ...

  10. bash_action

    https://stackoverflow.com/questions/12076326/how-to-install-maven2-on-redhat-linux #!/bin/bash # Tar ...