【HDU3065】 病毒侵袭持续中(AC自动机)
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 10504 Accepted Submission(s): 3701Problem Description小t非常感谢大家帮忙解决了他的上一个问题。然而病毒侵袭持续中。在小t的不懈努力下,他发现了网路中的“万恶之源”。这是一个庞大的病毒网站,他有着好多好多的病毒,但是这个网站包含的病毒很奇怪,这些病毒的特征码很短,而且只包含“英文大写字符”。当然小t好想好想为民除害,但是小t从来不打没有准备的战争。知己知彼,百战不殆,小t首先要做的是知道这个病毒网站特征:包含多少不同的病毒,每种病毒出现了多少次。大家能再帮帮他吗?Input第一行,一个整数N(1<=N<=1000),表示病毒特征码的个数。
接下来N行,每行表示一个病毒特征码,特征码字符串长度在1—50之间,并且只包含“英文大写字符”。任意两个病毒特征码,不会完全相同。
在这之后一行,表示“万恶之源”网站源码,源码字符串长度在2000000之内。字符串中字符都是ASCII码可见字符(不包括回车)。Output按以下格式每行一个,输出每个病毒出现次数。未出现的病毒不需要输出。
病毒特征码: 出现次数
冒号后有一个空格,按病毒特征码的输入顺序进行输出。Sample Input3
AA
BB
CC
ooxxCC%dAAAoen....ENDSample OutputAA: 2
CC: 1HintHit:
题目描述中没有被提及的所有情况都应该进行考虑。比如两个病毒特征码可能有相互包含或者有重叠的特征码段。
计数策略也可一定程度上从Sample中推测。
- #include<cstdio>
- #include<cstdlib>
- #include<cstring>
- #include<iostream>
- #include<algorithm>
- #include<queue>
- using namespace std;
- #define Maxn 100100
- #define Maxl 2000010
- #define Ml 60
- #define Mn 1010
- char ss[Mn][Ml];
- char s[Maxl];
- int p[Maxn],c[Maxn];
- int n;
- struct hp
- {
- int x,y,next;
- }qy[Maxn];int al;
- struct node
- {
- int son[],cnt,fail;
- int num,rt;
- }t[Maxn];int tot;
- int first[Maxn];
- void ins(int x,int y)
- {
- qy[++al].x=x;qy[al].y=y;
- qy[al].next=first[x];first[x]=al;
- }
- void upd(int x)
- {
- t[x].cnt=;
- memset(t[x].son,,sizeof(t[x].son));
- }
- void read_trie(int x)
- {
- scanf("%s",ss[x]+);
- int len=strlen(ss[x]+);
- int now=;
- for(int j=;j<=len;j++)
- {
- int ind=ss[x][j]-'A'+;
- if(!t[now].son[ind])
- t[now].son[ind]=++tot,upd(tot);
- now=t[now].son[ind];
- if(j==len) t[now].cnt++,p[x]=now;
- }
- }
- queue<int > q;
- void build_AC()
- {
- int i,j,x,y;
- while(!q.empty()) q.pop();
- q.push();
- while(!q.empty())
- {
- x=q.front();
- y=t[x].fail;
- for(j=;j<=;j++)
- {
- if(t[x].son[j])
- {
- q.push(t[x].son[j]);
- t[t[x].son[j]].fail=x?t[y].son[j]:x;
- ins(t[t[x].son[j]].fail,t[x].son[j]);
- }
- else t[x].son[j]=t[y].son[j];
- }
- q.pop();
- }
- }
- void dfs(int x)
- {
- t[x].num=++al;t[x].rt=t[x].num;
- for(int i=first[x];i;i=qy[i].next)
- dfs(qy[i].y),t[x].rt=t[qy[i].y].rt;
- }
- void dfs2(int x)
- {
- scanf("%s",s+);
- int len=strlen(s+);
- int now=;
- for(int j=;j<=len;j++)
- {
- if(s[j]<'A'||s[j]>'Z') {now=;continue;}
- int ind=s[j]-'A'+;
- now=t[now].son[ind];
- c[t[now].num]++;
- }
- }
- void init()
- {
- memset(first,,sizeof(first));
- tot=;upd();
- for(int i=;i<=n;i++)
- {
- read_trie(i);
- }
- al=;build_AC();al=;
- dfs();
- memset(c,,sizeof(c));
- dfs2();c[]=;
- for(int i=;i<=al;i++) c[i]=c[i-]+c[i];
- for(int i=;i<=n;i++)
- {
- int ans=;
- ans=c[t[p[i]].rt]-c[t[p[i]].num-];
- if(ans!=) printf("%s: %d\n",ss[i]+,ans);
- }
- }
- int main()
- {
- while(scanf("%d",&n)!=EOF)
- {
- init();
- }
- return ;
- }
[HDU3065]
2016-06-17 13:46:45
【HDU3065】 病毒侵袭持续中(AC自动机)的更多相关文章
- hdu3065 病毒侵袭持续中 AC自动机入门题 N(N <= 1000)个长度不大于50的模式串(保证所有的模式串都不相同), 一个长度不大于2000000的待匹配串,求模式串在待匹配串中的出现次数。
/** 题目:hdu3065 病毒侵袭持续中 链接:http://acm.hdu.edu.cn/showproblem.php?pid=3065 题意:N(N <= 1000)个长度不大于50的 ...
- HDU3065 病毒侵袭持续中 —— AC自动机
题目链接:https://vjudge.net/problem/HDU-3065 病毒侵袭持续中 Time Limit: 2000/1000 MS (Java/Others) Memory Li ...
- hdu----(3065)病毒侵袭持续中(AC自动机)
病毒侵袭持续中 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
- HDU-3065 病毒侵袭持续中 AC自动机又是一板子!
病毒侵袭持续中 上一题是求出现多少病毒输出病毒序号,而这题输出每个病毒出现的次数.这题有字典树基础都能做出来,把叶子节点用相应的编号标记起来,匹配的时候遍历到叶子节点用一个数组把次数存起来就行了. 有 ...
- [hdu3065]病毒侵袭持续中(AC自动机)
题意:给出多种病毒的号码和特征码,计算在某串中各病毒匹配的次数. 解题关键:AC自动机模板题,多组输入坑人. #include<bits/stdc++.h> using namespace ...
- HDU 3065 病毒侵袭持续中 (AC自动机)
题目链接 Problem Description 小t非常感谢大家帮忙解决了他的上一个问题.然而病毒侵袭持续中.在小t的不懈努力下,他发现了网路中的"万恶之源".这是一个庞大的病毒 ...
- hdoj 3065 病毒侵袭持续中(AC自动机)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3065 思路分析:问题需要模式匹配多个模式串,需要注意的是模式串会包含和重叠,需要对AC自动机的匹配过 ...
- hdu3065 病毒侵袭持续中【AC自动机】
病毒侵袭持续中 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
- hdu3065 病毒侵袭持续中
题目地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=3065 题目: 病毒侵袭持续中 Time Limit: 2000/1000 MS (Java ...
- HDU-3065 病毒侵袭持续中 字符串问题 AC自动机
题目链接:https://cn.vjudge.net/problem/HDU-3065 题意 跟上一道题是几乎一模一样,这次是统计关键词的出现次数 一个相当坑的地方,注意多组样例 思路 套模版 改in ...
随机推荐
- Memcached Java Client with sample program--reference
In my previous post, I listed down most common telnet commands for memcached with sample execution t ...
- ServletContext对象--三大域对象
Servlet三大域对象的应用 request.session.application(ServletContext) ServletContext是一个全局的储存信息的空间,服务器开始就存在,服务器 ...
- Java的浮点数
为了防止无良网站的爬虫抓取文章,特此标识,转载请注明文章出处.LaplaceDemon/ShiJiaqi. http://www.cnblogs.com/shijiaqi1066/p/5160771. ...
- 定位 position
html结构是fixed包裹relative,relative包裹absolute position:relative;相对定位 a 不影响元素本身的特性 b 不使元素脱离文档流(元素移动之后原始位置 ...
- inline-block间隙原因和解决方法(web前端问题)
申明:IE7无法测试,所以下面说的IE6指IE6和IE7 1,遇到的问题 Normal 0 7.8 磅 0 2 false false false EN-US ZH-CN X-NONE /* Styl ...
- html 之前学习响应式的笔记
响应式的设计,根据用户设备的不同,用户屏幕大小不同,提供不同的网页设计http://mediaqueri.es/PhoneGap 使用2,如何模拟手机设备chome 浏览器 在32以上设备检测用 de ...
- (转)Java爬虫,信息抓取的实现
转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/23272657 今天公司有个需求,需要做一些指定网站查询后的数据的抓取,于是花了点 ...
- Android常用错误解决汇总
一.No active compatible AVD's or devices found. Relaunch this configuration after connecting a device ...
- phpMyAdmin教程 之 创建新用户/导入/导出数据库
盗用了被人的教程. 需要看就点击进去吧.复制过来实在是过意不去 http://www.wpdaxue.com/phpmyadmin-import-export-database.html
- 关于基于.net的WEB程序开发所需要的一些技术归纳
前提: 最近公司里有一个同事,年龄比我大几岁,但是由于是转行来做开发的,许多的关于.net开发技术不是很入行,所以总是会问我一些东西,基于自己以前的一些 经验,总是会愿意给他讲一些总结性的东西,希望他 ...