HDUnbsp;3065nbsp;病毒侵袭持续中(AC自动…

2023-10-20 03:38

本文主要是介绍HDUnbsp;3065nbsp;病毒侵袭持续中(AC自动…,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3065

 

分析见上一篇博客

直接附代码:

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

typedef struct point{
   int count;
   struct point *fail,*next[26];
}*Tree,Node;
Tree root,Q[50008];
char str[2000008];
int num[1008];

Tree NEW()
{
   int i;
   Tree p;
   p=(Tree)malloc(sizeof(Node));
   for(i=0;i<26;i++)
       p->next[i]=NULL;
   p->fail=NULL;
   p->count=-1;
   return p;
}

void Build(char ss[],int u)
{
   int i=0;
   Tree p,s;
   p=root;
   while(ss[i])
   {
       if(p->next[ss[i]-'A']==NULL)
       {
           s=NEW();
           p->next[ss[i]-'A']=s;
           p=s;
       }
       else p=p->next[ss[i]-'A'];
       i++;
   }
   p->count=u;

}

void AC_Automation()
{
   int i,front=0,rear=0;
   Tree p,temp;
   root->fail=NULL;
   Q[front++]=root;
   while(rear<front)
   {
       temp=Q[rear++];
       p=NULL;
       for(i=0;i<26;i++)
       {
           if(temp->next[i]!=NULL)
           {
               if(temp==root)temp->next[i]->fail=root;
               else
               {
                   p=temp->fail;
                   while(p!=NULL)
                   {
                       if(p->next[i]!=NULL)
                       {
                           temp->next[i]->fail=p->next[i];
                           break;
                       }
                       p=p->fail;
                   }
                   if(p==NULL)temp->next[i]->fail=root;
               }
               Q[front++]=temp->next[i];
           }
       }
   }
}

void search()
{
   int i=0;
   Tree p=root,temp;
   memset(num,0,sizeof(num));
   while(str[i])
   {
       if(str[i]>='A' && str[i]<='Z')
       {
           while(p->next[str[i]-'A']==NULL && p!=root)p=p->fail;

           p=p->next[str[i]-'A'];
           if(p==NULL)p=root;
           temp=p;
           while(temp!=root)
           {
               if(temp->count>=0)
                   num[temp->count]++;
               temp=temp->fail;
           }
       }
       else p=root;
       i++;
   }
}

int main()
{
   int n,i;
   char ss[1008][55];
   while(scanf("%d",&n)!=EOF)
   {
   root=NEW();
   for(i=0;i<n;i++)
   {
       scanf("%s",ss[i]);
       Build(ss[i],i);
   }
   AC_Automation();
   getchar();
   gets(str);
   search();
   for(i=0;i<n;i++)
       if(num[i]!=0)
       printf("%s: %d\n",ss[i],num[i]);
   }
   return 0;
}

这篇关于HDUnbsp;3065nbsp;病毒侵袭持续中(AC自动…的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/244389

相关文章

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

Python使用pynput模拟实现键盘自动输入工具

《Python使用pynput模拟实现键盘自动输入工具》在日常办公和软件开发中,我们经常需要处理大量重复的文本输入工作,所以本文就来和大家介绍一款使用Python的PyQt5库结合pynput键盘控制... 目录概述:当自动化遇上可视化功能全景图核心功能矩阵技术栈深度效果展示使用教程四步操作指南核心代码解析

SpringBoot实现文件记录日志及日志文件自动归档和压缩

《SpringBoot实现文件记录日志及日志文件自动归档和压缩》Logback是Java日志框架,通过Logger收集日志并经Appender输出至控制台、文件等,SpringBoot配置logbac... 目录1、什么是Logback2、SpringBoot实现文件记录日志,日志文件自动归档和压缩2.1、

SpringCloud使用Nacos 配置中心实现配置自动刷新功能使用

《SpringCloud使用Nacos配置中心实现配置自动刷新功能使用》SpringCloud项目中使用Nacos作为配置中心可以方便开发及运维人员随时查看配置信息,及配置共享,并且Nacos支持配... 目录前言一、Nacos中集中配置方式?二、使用步骤1.使用$Value 注解2.使用@Configur

Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)

《Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)》本文主要介绍了Golang分布式锁实现,采用Redis+Lua脚本确保原子性,持可重入和自动续期,用于防止超卖及重复下单,具有一定... 目录1 概念应用场景分布式锁必备特性2 思路分析宕机与过期防止误删keyLua保证原子性可重入锁自动