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. nrf51822中app_button 的应用

    Button Handler(按键处理程序) 按键处理程序是使用GPIOTE(GPIO Task and Event)的处理机制实现的,为了防止按键的抖动.在GPIOTE event(事件)处理程序中 ...

  2. Microsoft Dynamics CRM Server 2013软件安装要求

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveV9mMTIz/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/d ...

  3. 走入asp.net mvc不归路:[6]linq常见用法

    asp.net mvc结合linq,先不说性能问题,对于增删查改的操作还是相当方便的.以下我们就来介绍一下linq在asp.net mvc的Controller中的常见用法. 1 首先来看看整个数据表 ...

  4. vs2017 使用GitHub 推送到远程仓储

    vs2017下使用github拓展工具无法成功推送,提示“未能推送到远程存储库” 窗口错误显示:发布到远程存储库时遇到错误: Git failed with a fatal error. HttpRe ...

  5. JS 计算2个日期相差的天数

    <span style="font-size:18px;">function getDays(strDateStart,strDateEnd){ var strSepa ...

  6. JAVA 保留两位小数

    package com.oracle.pojo; import java.math.BigDecimal; import java.text.DecimalFormat; import java.te ...

  7. DICOM-RT:放疗流程与參与角色

    背景: 放疗是一个复杂的过程,同一时候须要肿瘤医师.模拟定位技师.剂量师.物理师.治疗技师.护士等多重角色參与.总体流程涉及到成像系统.定位系统.计划系统.治疗系统.质控QA系统.信息管理系统等多个独 ...

  8. 【特征检測】BRIEF特征点描写叙述算法

    简单介绍 BRIEF是2010年的一篇名为<BRIEF:Binary Robust Independent Elementary Features>的文章中提出,BRIEF是对已检測到的特 ...

  9. 【bzoj2761】【JLOI2011】【不反复数字】【平衡树】

    Description 给出N个数,要求把当中反复的去掉.仅仅保留第一次出现的数. 比如,给出的数为1 2 18 3 3 19 2 3 6 5 4.当中2和3有反复.去除后的结果为1 2 18 3 1 ...

  10. 网页 H5“线条” 特效实现方式(canvas-nest)

    先上图 (看博客空白处也可以呦): 前一阵浏览网站的时候,发现了这个好玩的东西,一直想找找怎么实现的,今天忙里偷闲,上网搜了一下,发现实现起来特别简单. 只需要在网页body里引入一个<scri ...