UVALive-4670 Dominating Patterns(AC自动机)
题目大意:找出出现次数最多的模式串。
题目分析:AC自动机裸题。
代码如下:
# include<iostream>
# include<cstdio>
# include<map>
# include<queue>
# include<cstring>
# include<algorithm>
using namespace std; const int N=20000; int ch[N][26];
string p[155];
char s[N*50+5];
int val[N];
int t[155];
int f[N+5];
int last[N+5];
map<string,int>mp;
map<int,string>mpp; struct AC
{
int cnt;
void init()
{
cnt=0;
memset(val,0,sizeof(val));
memset(ch,0,sizeof(ch));
memset(t,0,sizeof(t));
} void insert(string str,int v)
{
int n=str.size();
int root=0;
for(int i=0;i<n;++i){
int c=str[i]-'a';
if(!ch[root][c])
ch[root][c]=++cnt;
root=ch[root][c];
}
val[cnt]=v;
} void getFail()
{
queue<int>q;
f[0]=0;
for(int i=0;i<26;++i){
int u=ch[0][i];
if(!u) continue;
f[u]=0;
q.push(u);
last[u]=0;
}
while(!q.empty()){
int r=q.front();
q.pop();
for(int i=0;i<26;++i){
int u=ch[r][i];
if(!u) continue;
q.push(u);
int v=f[r];
while(v&&!ch[v][i]) v=f[v];
f[u]=ch[v][i];
last[u]=val[f[u]]?f[u]:last[f[u]];
}
}
} void ac(char *s)
{
int n=strlen(s);
int j=0;
for(int i=0;i<n;++i){
int c=s[i]-'a';
while(j&&!ch[j][c]) j=f[j];
j=ch[j][c];
if(val[j]) getResult(j);
else if(last[j]) getResult(last[j]);
}
} void getResult(int u)
{
if(u==0) return ;
if(u) ++t[val[u]];
getResult(last[u]);
}
}ac; int main()
{
int n;
while(~scanf("%d",&n)&&n)
{
ac.init();
int cnt=0;
mp.clear();
mpp.clear();
for(int i=0;i<n;++i){
cin>>p[i];
if(mp[p[i]]==0) mp[p[i]]=++cnt;
ac.insert(p[i],cnt);
mpp[cnt]=p[i];
}
scanf("%s",s); ac.getFail();
ac.ac(s);
int maxn=0;
for(int i=1;i<=cnt;++i)
maxn=max(maxn,t[i]);
cout<<maxn<<endl;
for(int i=1;i<=cnt;++i)
if(t[i]==maxn) cout<<mpp[i]<<endl;
}
return 0;
}
UVALive-4670 Dominating Patterns(AC自动机)的更多相关文章
- UVALive 4670 Dominating Patterns --AC自动机第一题
		
题意:多个模板串,一个文本串,求出那些模板串在文本串中出现次数最多. 解法:AC自动机入门模板题. 代码: #include <iostream> #include <cstdio& ...
 - UVALive - 4670 Dominating Patterns AC  自动机
		
input n 1<=n<=150 word1 word2 ... wordn 1<=len(wirdi)<=70 s 1<=len(s)<=1000000 out ...
 - LA 4670 Dominating Patterns (AC自动机)
		
题意:给定一个一篇文章,然后下面有一些单词,问这些单词在这文章中出现过几次. 析:这是一个AC自动机的裸板,最后在匹配完之后再统计数目就好. 代码如下: #pragma comment(linker, ...
 - 【暑假】[实用数据结构]UVAlive 4670 Dominating Patterns
		
UVAlive 4670 Dominating Patterns 题目: Dominating Patterns Time Limit: 3000MS Memory Limit: Unkn ...
 - UVALive 4670 Dominating Patterns (AC自动机)
		
AC自动机的裸题.学了kmp和Trie以后不难看懂. 有一些变化,比如0的定义和f的指向,和建立失配边,以及多了后缀连接数组last.没有试过把失配边直接当成普通边(一开始还是先这样写吧). #inc ...
 - uvalive 4670 Dominating Patterns
		
在文本串中找出现次数最多的子串. 思路:AC自动机模板+修改一下print函数. #include<stdio.h> #include<math.h> #include< ...
 - UVa1449 - Dominating Patterns(AC自动机)
		
题目大意 给定n个由小写字母组成的字符串和一个文本串T,你的任务是找出那些字符串在文本中出现的次数最多 题解 一个文本串,多个模式串,这刚好是AC自动机处理的问题 代码: #include <i ...
 - UVa 1449 - Dominating Patterns (AC自动机)
		
题目大意:给出多个字符串模板,并给出一个文本串,求在文本串中出现最多的模板,输出最多的次数并输出该模板(若有多个满足,则按输入顺序输出). 思路:赤裸裸的 AC自动机,上模板. 代码: #includ ...
 - LA4670 Dominating Patterns  AC自动机模板
		
Dominating Patterns 每次看着别人的代码改成自己的模板都很头大...空间少了个0卡了好久 裸题,用比map + string更高效的vector代替蓝书中的处理方法 #include ...
 - UVa Live 4670 Dominating Patterns - Aho-Corasick自动机
		
题目传送门 快速的通道I 快速的通道II 题目大意 给定一堆短串,和一个文本串,问哪些短串在文本串中出现的次数最多. 我觉得刘汝佳的做法,时间复杂度有问题.只是似乎这道题短串串长太短不好卡.比如给出的 ...
 
随机推荐
- 最大联通子数组之和(dfs,记忆化搜索,状态压缩)
			
最大联通子数组,这次的题目,我采用的方法为dfs搜索,按照已经取到的数v[][],来进行搜索过程的状态转移,每次对v[][]中标记为1的所有元素依次取其相邻的未被标记为1的元素,将其标记为1,然而,这 ...
 - DotNetBar v12.9.0.0 Fully Cracked
			
更新信息: http://www.devcomponents.com/customeronly/releasenotes.asp?p=dnbwf&v=12.9.0.0 如果遇到破解问题可以与我 ...
 - .net 小问题集结
			
1 .net中新建的项目,调试时,提示"由于未在web.config文件中启用调试,因此无法在调试模式下运行该页.您希望做什么?" 解决办法: 在web.config文件中,将&l ...
 - java运算符的优先级
			
Java 编辑 运算符 结合性 [ ] . ( ) (方法调用) 从左向右 ! ~ ++ -- +(一元运算) -(一元运算) 从右向左 * / % 从左向右 + - 从左向右 << & ...
 - IOS NSInvocation用法简介
			
IOS NSInvocation用法简介 2012-10-25 19:59 来源:博客园 作者:csj007523 字号:T|T [摘要]在 iOS中可以直接调用某个对象的消息方式有两种,其中一种就是 ...
 - C# 展开和折叠代码的快捷键(总结)
			
C# 展开和折叠代码的快捷键 VS2005代码编辑器的展开和折叠代码确实很方便和实用.以下是展开代码和折叠代码所用到的快捷键,很常用: Ctrl + M + O: 折叠所有方法 Ctrl + M + ...
 - SQL实现字段内容查找和替换
 - java抽象类与接口的区别及用法
			
java抽象类与接口的区别及用法 一.抽象类里面的方法可以有实现,但是接口里面的方法确是只能声明. 二.接口是设计的结果 :抽象类是重构的结果 . 三.java不支持多重继承,所以继承抽象类只能继承一 ...
 - Azure Automation:存储帐户之间blob拷贝
			
在两个存储帐户之间进行blob拷贝,在客户端,使用Azue PowerShell脚本, 用存储帐户上下文(New-AzureStorageContext)来获取某个StorageAccount中的Co ...
 - Magento的价格去掉小数点
			
Magento的默认情况,价格后面是有小数点的,我们来看下如何正确的来去掉小数点. 1.复制如下路径的文件 app/code/core/Mage/Directory/Model/Currency.ph ...