[POI2000]病毒
题面
Sol
建出AC自动机后DFS能走的点,如果能走回来就可行
# include <bits/stdc++.h>
# define IL inline
# define RG register
# define Fill(a, b) memset(a, b, sizeof(a))
using namespace std;
typedef long long ll;
const int _(3e5 + 5);
int ch[2][_], tot, fail[_], n, vis[_], in[_];
bool cnt[_];
char w[_];
queue <int> Q;
IL void Insert(){
    RG int l = strlen(w), x = 0;
    for(RG int i = 0; i < l; ++i){
        RG int c = w[i] - '0';
        if(!ch[c][x]) ch[c][x] = ++tot;
        x = ch[c][x];
    }
    cnt[x] = 1;
}
IL void GetFail(){
    for(RG int i = 0; i < 2; ++i) if(ch[i][0]) Q.push(ch[i][0]);
    while(!Q.empty()){
        RG int fa = Q.front(); Q.pop();
        for(RG int i = 0; i < 2; ++i)
            if(ch[i][fa]) fail[ch[i][fa]] = ch[i][fail[fa]], Q.push(ch[i][fa]);
            else ch[i][fa] = ch[i][fail[fa]];
		cnt[fa] |= cnt[fail[fa]];
    }
}
IL void Dfs(RG int x){
	in[x] = vis[x] = 1;
	for(RG int i = 0; i < 2; ++i){
		if(in[ch[i][x]]){  puts("TAK"); exit(0);  }
		if(vis[ch[i][x]] || cnt[ch[i][x]]) continue;
		Dfs(ch[i][x]);
	}
	in[x] = 0;
}
int main(RG int argc, RG char* argv[]){
    scanf("%d", &n);
    for(RG int i = 1; i <= n; ++i) scanf(" %s", w), Insert();
    GetFail();
	Dfs(0);
	puts("NIE");
    return 0;
}
												
											[POI2000]病毒的更多相关文章
- BZOJ 2938: [Poi2000]病毒 [AC自动机 拓扑排序]
		
2938: [Poi2000]病毒 题意:判断是否存在无限长的不含模式串的字符串.只有01. 建出套路DP的转移图,判断有环就行了 练习一下拓扑排序 #include <iostream> ...
 - BZOJ_2938_[Poi2000]病毒_AC自动机
		
BZOJ_2938_[Poi2000]病毒_AC自动机 Description 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们 ...
 - P2444 [POI2000]病毒
		
P2444 [POI2000]病毒 题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已 ...
 - BZOJ 2938: [Poi2000]病毒
		
2938: [Poi2000]病毒 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 693 Solved: 360[Submit][Status][Di ...
 - [洛谷P2444] [POI2000]病毒
		
洛谷题目链接:[POI2000]病毒 题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会 ...
 - [POI2000]病毒 --- AC自动机
		
[POI2000]病毒 题目描述: 二进制病毒审查委员会最近发现了如下的规律: 某些确定的二进制串是病毒的代码. 如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的. 现在委员会已经找 ...
 - 【BZOJ2938】[Poi2000]病毒 AC自动机+DFS
		
[BZOJ2938][Poi2000]病毒 Description 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码 ...
 - BZOJ2938: [Poi2000]病毒(AC自动机)
		
2938: [Poi2000]病毒 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 1678 Solved: 849[Submit][Status][D ...
 - 洛谷 P2444 [POI2000]病毒 解题报告
		
P2444 [POI2000]病毒 题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已 ...
 - BZOJ2938 [Poi2000]病毒 和 BZOJ5261 Rhyme
		
[Poi2000]病毒 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已经找出了所有的病毒代码 ...
 
随机推荐
- Jenkins 不同角色不同视图及不同权限设置
			
由于jenkins默认的权限管理体系不支持用户组或角色的配置,因此需要安装第三发插件来支持角色的配置,本文将使用Role Strategy Plugin,介绍页面:https://wiki.jenki ...
 - 微信小程序 页面跳转传递数据
			
点击view 跳转页面 <view class="album_image" data-album-obj="{{item}}" bindtap=" ...
 - Python标准异常总结
			
Python标准异常总结 AssertionError 断言语句(assert)失败 AttributeError 尝试访问未知的对象属性 EOFError 用户输入文件末尾标志EOF(Ctrl+d ...
 - Egret学习笔记 (Egret打飞机-1.大致思路)
			
大致看了一遍Egret的官方文档,就开始打算使用Egret来开发一个打飞机游戏. 首先来捋一捋思路,先来看一看一个打飞机游戏的图片 基本上一个打飞机游戏分为 开始游戏 ----------进入游戏 ...
 - windows转mac-开发环境搭建(一):mac上搭建maven环境
			
1.下载地址:https://maven.apache.org/download.cgi 将下载的maven压缩包进行解压,放入到一个方便管理的文件当中,解压命令:tar zxvf apache-ma ...
 - 【BZOJ2127】happiness
			
Time Limit: 1000 ms Memory Limit: 256 MB Description 高一一班的座位表是个n*m的矩阵,经过一个学期的相处,每个同学和前后左右相邻的同学互相成为 ...
 - C语言老司机学Python (六)- 多线程
			
前面的1-5都是比较基础的东西,能做的事情也有限. 从本节起,随着更多进阶技术的掌握,渐渐就可以用Python开始浪了. Python3使用threading模块来实现线程操作. 根据在其他语言处学来 ...
 - DTCMS插件的制作实例电子资源管理(四)URL重写
			
总目录 插件目录结构(一) Admin后台页面编写(二) 前台模板页编写(三) URL重写(四) 本实例旨在以一个实际的项目中的例子来介绍如何在dtcms中制作插件,本系列文章非入门教程,部分逻辑实现 ...
 - windows与虚拟机linux能ping通设置
			
作为以后参考所用. 首先,介绍如何在VMWare中设置linux的网络.一般网络选项有Bridged,NAT,host-only几种,本次以host-only作详细说明,如下图: 在选择host-on ...
 - Ubuntu的shell之bash和dash
			
Ubuntu的 shell 默认安装的是 dash,而不是 bash. 运行以下命令查看 sh 的详细信息,确认 shell 对应的程序是哪个: $ls -al /bin/sh dash 比 bash ...