2774: Poi2000 病毒

Time Limit: 1 Sec  Memory Limit: 128 MB
Submit: 5  Solved: 4
[Submit][Status][Web Board]

Description

二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码。
如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的。现在委员会已经找出了所有的病毒代码段
试问,是否存在一个无限长的安全的二进制代码。
示例:
例如如果{011, 11, 00000}为病毒代码段,那么一个可能的无限长安全代码就是010101…。如果{01, 11, 000000}为病毒代码段,那么就不存在一个无限长的安全代码。
任务:
请写一个程序:
读入病毒代码,判断是否存在一个无限长的安全代码;

Input

第一行包括一个整数n,表示病毒代码段的数目。
以下的n行每一行都包括一个非空的01字符串——就是一个病毒代码段。所有病毒代码段的总长度不超过30000。

Output

输出一个单词:
TAK——假如存在这样的代码;
NIE——如果不存在。

Sample Input

3
01
11
00000

Sample Output

NIE

HINT

 

Source

题解:  

  首先我们把所有串建一个AC自动机

  方便起见我们直接把fail指针合并到子结点

  如果一个串能无限长,也就是说它可以在AC自动机上一直进行匹配但就是匹配不上

  也就是说匹配指针不能走到val为1的结点,设这个点为x

  即root..x是一个病毒串

  那么fail指针指向x的y也不能走

  因为root..x是root..y的一个后缀

  处理出来判断有向图是否有环

  dfs即可

 
#include<iostream>
#include<cstring>
#include<cstdio>
#define maxn 30001
using namespace std;
int n,tot;
char s[maxn];
int sum[maxn],son[maxn][],lis[maxn],fai[maxn];
int ins[maxn],vis[maxn];
void insert()
{
int p=;
scanf("%s",s+);
for (int i=; s[i]; p=son[p][s[i]-''],i++) if (!son[p][s[i]-'']) son[p][s[i]-'']=++tot;
sum[p]=;
}
void failed()
{
int head=,tail=; lis[]=; fai[]=-;
while (head<tail)
{
int x=lis[++head];
for (int i=; i<=; i++)
{
int v=son[x][i];
if (!v)
{
son[x][i]=son[fai[x]][i];
continue;
}
lis[++tail]=v;
int p=fai[x];
while (p!=- && !son[p][i]) p=fai[p];
if (p==-) fai[v]=;
else
fai[v]=son[p][i],sum[v]|=sum[son[p][i]]; }
}
}
bool dfs(int x)
{
ins[x]=;
for (int i=; i<; i++)
{
int v=son[x][i];
if (ins[v]) return ;
if (vis[v] || sum[v]) continue;
vis[v]=;
if (dfs(v)) return ;
}
ins[x]=;
return ;
}
int main()
{
cin>>n; tot=; memset(son,,sizeof(son));
for (int i=; i<=n; i++) insert();
failed();
if (dfs()==) cout<<"TAK"<<endl; else cout<<"NIE"<<endl;
}

http://begin.lydsy.com/JudgeOnline/problem.php?id=2774(poi病毒)的更多相关文章

  1. Zju1290 Word-Search Wonder(http://begin.lydsy.com/JudgeOnline/problem.php?id=2768)

    2768: Zju1290 Word-Search Wonder Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 4  Solved: 2[Submit] ...

  2. http://begin.lydsy.com/JudgeOnline/problem.php?id=2770(PKU2503 Babelfish)

    2770: PKU2503 Babelfish Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 2  Solved: 2[Submit][Status][ ...

  3. 题目连接:http://acm.zznu.edu.cn/problem.php?id=1329

    题目大意: 定理:把一个至少两位的正整数的个位数字去掉,再从余下的数中减去个位数的5倍.当且仅当差是17的倍数时,原数也是17的倍数 . 例如,34是17的倍数,因为3-20=-17是17的倍数:20 ...

  4. 在线判题 (模拟)http://202.196.1.132/problem.php?id=1164

    #include<stdio.h> #include<math.h> #include<string.h> #include<stdlib.h> #de ...

  5. begin lydsy 2731

    2731: 最长重复子串 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 6  Solved: 4[Submit][Status][Web Board] ...

  6. BZOJ(begin) 1328 [Usaco2003 Open]Jumping Cows:贪心【波峰波谷模型】

    题目链接:http://begin.lydsy.com/JudgeOnline/problem.php?id=1328 题意: 给你一个长度为n的正整数序列. 可以选任意个数字,只能从左往右选. 偶数 ...

  7. (最小路径覆盖) News 消息传递 (hust OJ 2604)

    http://begin.lydsy.com/JudgeOnline/problem.php?id=2604   Description 总部最近打算向下面的N个工作人员发出了一条秘密消息.因为它是机 ...

  8. Hash_集合

    #include <iostream> #include <cstdio> #include <algorithm> #include <cstring> ...

  9. [Noi2016十连测第五场]二进制的世界

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

随机推荐

  1. MyEclipse8.5优化经验

    第一步: 取消自动validation    validation有一堆,什么xml.jsp.jsf.js等等,我们没有必要全部都去自动校验一下,只是需要的时候才会手工校验一下!    取消方法:   ...

  2. Ubuntu和Redhat(Debian)的差别

    这两个最大的区别在包管理模式上. 都是用的Linux核心构架的. Redhat主要集中在 企业级服务器版的制作 是推动LINUX商业化最成功的公司 Redhat对应的桌面版制作 都是由Fedora社区 ...

  3. OpenGL------三维变换

    我们生活在一个三维的世界——如果要观察一个物体,我们可以:1.从不同的位置去观察它.(视图变换)2.移动或者旋转它,当然了,如果它只是计算机里面的物体,我们还可以放大或缩小它.(模型变换)3.如果把物 ...

  4. CentOS 修改DNS,固定IP等操作(网络)

    1.修改DNS 修改对应网卡的DNS的配置文件 vi /etc/resolv.conf 内容格式(西工大) nameserver 114.114.114.114 nameserver 202.117. ...

  5. 程序员 10Tips

    理解技术债务 技术债务就像信用卡一样,会有很高的利息率,时间越长,修复所花的代价就越大,程序员对这个要有深刻的认识.同时团队应该培养一种保证设计质量的文化,应当鼓励重构.同时也应当鼓励其它有关代码质量 ...

  6. IE6下最小19px像素

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  7. iOS开发中控制器切换方式Modal

    简介 在iPhone开发中 Modal是一种常见的切换控制器的方式 默认是从屏幕底部往上弹出,直到完全盖住后面的内容为止 在iPad开发中 Modal的使用频率也是非常高的 对比iPhone开发,Mo ...

  8. 解决Only the original thread that created a view hierarchy can touch its views

    这种异常出现在子线程中处理UI操作产生的异常,将UI操作放在主线程中就OK了

  9. PAT (Advanced Level) 1061. Dating (20)

    简单模拟. #include<stdio.h> #include<string.h> ],s2[],s3[],s4[]; ][]={"MON ", &quo ...

  10. Chapter 1 First Sight——2

    "Bella," my mom said to me — the last of a thousand times — before I got on the plane. &qu ...