[POI2000]病毒

 [POI2000]病毒

题目描述

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

示例:

例如如果{011, 11, 00000}为病毒代码段,那么一个可能的无限长安全代码就是010101…。如果{01, 11, 000000}为病毒代码段,那么就不存在一个无限长的安全代码。

任务:

请写一个程序:

1.在文本文件WIR.IN中读入病毒代码;

2.判断是否存在一个无限长的安全代码;

3.将结果输出到文件WIR.OUT中。
 


solution

首先我们可以建出AC自动机

我们如果我们可以在ac自动机上找到一个环,且环上没有标记,那么我们就可以一直沿着它走了。

用dfs找环就可以了。

要注意一个,如果有一个点的fail被标记了,那么这个点也是不合法的(从根走到它一定会经过标记点)

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#define maxn 30005
using namespace std;
int n,tr[maxn][2],cnt,e[maxn],fail[maxn];
char ch[maxn];
bool vis[maxn],ins[maxn],fsy;
void inst(){
    int len=strlen(ch),p=0;
    for(int i=0;i<len;i++){
        if(!tr[p][ch[i]-'0'])tr[p][ch[i]-'0']=++cnt;
        p=tr[p][ch[i]-'0'];
    }
    e[p]=1;
}
void build(){
    queue<int>q;
    for(int j=0;j<2;j++)if(tr[0][j])q.push(tr[0][j]);
    while(!q.empty()){
        int x=q.front();q.pop();
        for(int i=0;i<2;i++){
            if(tr[x][i]){
                fail[tr[x][i]]=tr[fail[x]][i];
                e[tr[x][i]]|=e[fail[tr[x][i]]];
                q.push(tr[x][i]);
            }
            else tr[x][i]=tr[fail[x]][i];
        }
    }
}

void dfs(int x){
    for(int i=0;i<2;i++){
        if(!e[tr[x][i]]){
            if(vis[tr[x][i]]){
                if(ins[tr[x][i]]){fsy=1;return;}
            }
            else {
                ins[tr[x][i]]=1;vis[x]=1;
                dfs(tr[x][i]);
                ins[tr[x][i]]=0;
            }
        }
    }
    
}
int main(){
    cin>>n;
    for(int i=1;i<=n;i++){
        scanf("%s",&ch);inst();
    }
    build();
    dfs(0);
    if(fsy)puts("TAK");
    else puts("NIE");
    return 0;
}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
2000年,POI数据下载是指在该年下载位置信息(POI)相关数据的行为。POI是指感兴趣点(Point of Interest),即地理位置上具有特殊意义或价值的地点。下载POI数据是为了获取这些特定地点的位置和相关信息,以便用于地图导航、社交媒体、市场研究等领域。 2000年,随着信息技术的快速发展,人们对位置信息的需求也日益增加。下载POI数据成为了一种常见的行为,以便更好地了解和利用周围环境。在这一年,下载POI数据的主要方式是通过互联网进行。 以2000年为例,要下载POI数据,首先需要访问相关的互联网平台或网站,如地图服务提供商、旅行网站或地理信息系统。然后,在相应的界面中,可以选择特定的地理区域、类型的POI,以及数据格式(如CSV、XML或JSON)等。接下来,点击下载按钮或链接,系统将开始传输POI数据到用户的设备上。 下载完成后,用户可以将这些POI数据导入到相应的应用程序或软件中进行进一步的分析和利用。例如,可以基于这些数据开发地图导航应用,帮助用户找到特定的商店、餐厅或景点。同时,还可以将POI数据与其他数据集结合,进行更深入的市场研究,比如确定最佳营销地点或了解消费者的行为模式。 总而言之,2000年的POI数据下载是一种通过互联网获取位置信息的行为,以满足人们对于地理位置和相关信息的需求。这一技术的发展为地图导航、社交媒体和市场研究等领域提供了更多可能性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值