hdu 2896 病毒侵袭_ac自动机
题意:略
思路:套用ac自动机模板
- #include <iostream>
- #include<cstdio>
- #include<cstring>
- using namespace std;
- char str[11000];
- int total,head,tail;
- struct node{
- node *next[130];
- node *fail;
- int cnt,id;
- node(){
- fail=NULL;
- cnt=0;
- memset(next,NULL,sizeof(next));
- }
- }*q[500000];
- void insert(node *root,int id){
- node *p=root;
- int i=0,index;
- while(str[i]){
- index=str[i]-31;
- if(p->next[index]==NULL) p->next[index]=new node();
- p=p->next[index];
- i++;
- }
- p->cnt++;
- p->id=id;
- }
- void build_ac(node *root){
- root->fail=NULL;
- q[head++]=root;
- node *p=NULL;
- while(head!=tail){
- node *temp = q[tail++];
- for(int i=0;i<=128;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[head++]=temp->next[i];
- }
- }
- }
- }
- bool ans[1000];
- int cnt;
- int query(node *root){
- int i=0,index;
- node *p=root;
- while(str[i]){
- index=str[i]-31;
- while(p->next[index]==NULL&&p!=root) p=p->fail;
- p=p->next[index];
- p=(p==NULL)?root:p;
- node *temp=p;
- while(temp!=root&&temp->cnt>0){
- if(ans[temp->id]==false)
- cnt++,ans[temp->id]=true;
- temp=temp->fail;
- }
- i++;
- }
- }
- int main(int argc, char** argv) {
- int n,m,total,i,j;
- while(scanf("%d",&n)!=EOF){
- node *root=new node();
- head=tail=total=0;
- for(i=0;i<n;i++){
- scanf("%s",str);
- insert(root,i+1);
- }
- scanf("%d",&m);
- build_ac(root);
- for(i=1;i<=m;i++){
- memset(ans,false,sizeof(ans));
- cnt=0;
- scanf("%s",str);
- query(root);
- if(cnt>0){
- printf("web %d:",i);
- for(j=1;j<=500;j++)
- if(ans[j]==1)
- printf(" %d",j);
- printf("\n");
- total++;
- }
- }
- printf("total: %d\n",total);
- }
- return 0;
- }
hdu 2896 病毒侵袭_ac自动机的更多相关文章
- hdu 2896 病毒侵袭 ac自动机
/* hdu 2896 病毒侵袭 ac自动机 从题意得知,模式串中没有重复的串出现,所以结构体中可以将last[](后缀链接)数组去掉 last[]数组主要是记录具有相同后缀模式串的末尾节点编号 .本 ...
- hdu 2896 病毒侵袭 AC自动机(查找包含哪些子串)
病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- hdu 2896 病毒侵袭 AC自动机 基础题
病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDU 2896 病毒侵袭 (AC自己主动机)
pid=2896">http://acm.hdu.edu.cn/showproblem.php?pid=2896 病毒侵袭 Time Limit: 2000/1000 MS (Java ...
- HDU 2896 病毒侵袭(AC自动机水)
病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDU 2896 病毒侵袭(AC自动机)
病毒侵袭 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- HDU 2896 病毒侵袭【AC自动机】
<题目链接> Problem Description 当太阳的光辉逐渐被月亮遮蔽,世界失去了光明,大地迎来最黑暗的时刻....在这样的时刻,人们却异常兴奋——我们能在有生之年看到500年一 ...
- HDU 2896 病毒侵袭 【AC自动机】
HDU 2222 仅仅求出了和文本串匹配的模式串个数,本题要求求出匹配的模式串的编号. 不同的部分在代码中的注释部分. #include <cstdio> #include <cst ...
- HDU 2896 病毒侵袭 (AC自动机)
这题模板题.............但是竟然要去重........调试了半天才发现.................... #include <cstdio> #include <i ...
随机推荐
- Palindrome Partitioning 解答
Question Given a string s, partition s such that every substring of the partition is a palindrome. R ...
- Hive 3、Hive 的安装配置(本地derby模式)
这种方式是最简单的存储方式,只需要在hive-site.xml做如下配置便可; $ vim hive-site.xml <configuration> <property> ...
- WPF可视化控件打印
Introduction While coding an application that displays a detailed report in a ScrollViewer, it was d ...
- VS快捷编码方式
概念: 代码段是将预先定义好的可重用代码块快速插入到代码文件中,代码段提高了开发效率,增强了代码的可重用性:既节约了时间,又实现了不同开发人员间代码的共享.同时也可保证同一项目中代码风格的统一. ...
- POJ-1118(超时,但未找到原因)
#include<iostream> #include<map> #include<vector> using namespace std; //y=kx+z ty ...
- Oracle监听静态注册和动态注册
静态注册和动态注册总结 一.什么是注册? 注册就是将数据库作为一个服务注册到监听程序.客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库.这个服务名可能与实例名 ...
- Oracle11g x64使用Oracle SQL Developer报错:Unable to find a Java Virtual Machine
原因oracle 11g中安装的Oracle SQL Developer是32位的,而我们现在给他指定的java.exe却是64位的,所以会出现这种错误.解决方法1)从网上下载Oracle SQL D ...
- HTTP协议4之缓存--转
HTTP协议提供了非常强大的缓存机制, 了解这些缓存机制,对提高网站的性能非常有帮助. 缓存的概念 缓存这个东西真的是无处不在, 有浏览器端的缓存, 有服务器端的缓存,有代理服务器的缓存, 有ASP. ...
- django Model模型二及Model模型对数据库的操作
在django模型中负责与数据库交互的为Model层,Model层提供了一个基于orm的交互框架 一:创建一个最基本的Model from __future__ import unicode_lite ...
- PHP学习笔记十五【面向对象二】
<?php class Cat{ //public 访问修饰符 public $name; public $age; } //创建 $cat1=new Cat; $cat1->name=& ...