模板—字符串—AC自动机(多模式串,单文本串)
模板—字符串—AC自动机(多模式串,单文本串)
Code:
#include <queue>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define N 1000010
int ch[N][26],fl[N],head[N],to[N],nxt[N],size[N],pos[N],en[N],n,ans; char str[N];
namespace AC
{
int idx,cnt;
void add(int a,int b) {nxt[++idx]=head[a],to[idx]=b,head[a]=idx;}
void insert(int id,int len)
{
int p=0;
for(int i=1;i<=len;i++)
{
if(!ch[p][str[i]-'a'])
ch[p][str[i]-'a']=++cnt;
p=ch[p][str[i]-'a'];
} pos[id]=p,en[p]++;
}
void dfs(int p)
{
size[p]=1;
for(int i=head[p];i;i=nxt[i])
dfs(to[i]),size[p]+=size[to[i]];
}
void bfs()
{
idx=0; queue <int> q;
for(int i=0;i<26;i++) if(ch[0][i])
q.push(ch[0][i]),add(0,ch[0][i]);
while(!q.empty())
{
int p=q.front(); q.pop();
for(int i=0;i<26;i++)
{
int &v=ch[p][i];
if(!v) {v=ch[fl[p]][i];continue;}
fl[v]=ch[fl[p]][i],q.push(v),add(fl[v],v);
}
} dfs(0);
}
void find(int l)
{
int p=0;
for(int i=1;i<=l;i++)
{
p=ch[p][str[i]-'a']; if(!p) return;
for(int j=p;j&&en[j]!=-1;j=fl[j])
ans+=en[j],en[j]=-1;
}
}
}
using namespace AC;
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%s",str+1),insert(i,strlen(str+1)); bfs();
scanf("%s",str+1),find(strlen(str+1)),printf("%d\n",ans);
}
模板—字符串—AC自动机(多模式串,单文本串)的更多相关文章
- 模板—字符串—KMP(单模式串,单文本串)
		
模板—字符串—KMP(单模式串,单文本串) Code: #include <cstdio> #include <cstring> #include <algorithm& ...
 - AC 自动机——多模式串匹配
		
网站上的敏感词过滤是怎么实现的呢? 实际上,这些功能最基本的原理就是字符串匹配算法,也就是通过维护一个敏感词的字典,当用户输入一段文字内容后,通过字符串匹配算法来检查用户输入的内容是否包含敏感词. B ...
 - P3808 【模板】AC自动机(简单版)
		
题目背景 这是一道简单的AC自动机模板题. 用于检测正确性以及算法常数. 为了防止卡OJ,在保证正确的基础上只有两组数据,请不要恶意提交. 管理员提示:本题数据内有重复的单词,且重复单词应该计算多次, ...
 - 【学时总结&模板时间】◆学时·10 & 模板·3◆ AC自动机
		
◇学时·10 & 模板·3◇ AC自动机 跟着高中上课……讲AC自动机的扩展运用.然而连KMP.trie字典树都不怎么会用的我一脸懵逼<(_ _)> 花一上午自学了一下AC自动机 ...
 - (模板)AC自动机模板
		
模板1. 给出模式串和文本串,文本串长度小于1e6,模式串长度之和小于1e6,求文本串中有多少模式串出现. 题目链接:https://www.luogu.org/problem/P3808 AC co ...
 - 洛谷P3808 【模板】AC自动机(简单版)
		
题目背景 这是一道简单的AC自动机模板题. 用于检测正确性以及算法常数. 为了防止卡OJ,在保证正确的基础上只有两组数据,请不要恶意提交. 管理员提示:本题数据内有重复的单词,且重复单词应该计算多次, ...
 - P3796 【模板】AC自动机(加强版)
		
P3796 [模板]AC自动机(加强版) https://www.luogu.org/problemnew/show/P3796 题目描述 有NN个由小写字母组成的模式串以及一个文本串TT.每个模式串 ...
 - 模板】AC自动机(简单版)
		
模板]AC自动机(简单版) https://www.luogu.org/problemnew/show/P3808 这是一道简单的AC自动机模板题. 用于检测正确性以及算法常数. 为了防止卡OJ,在保 ...
 - 【刷题】洛谷 P3808 【模板】AC自动机(简单版)
		
题目背景 这是一道简单的AC自动机模板题. 用于检测正确性以及算法常数. 为了防止卡OJ,在保证正确的基础上只有两组数据,请不要恶意提交. 管理员提示:本题数据内有重复的单词,且重复单词应该计算多次, ...
 
随机推荐
- JMeter获取复杂的JSON串中的参数的值
			
大家好,这篇博文中主要是介绍怎么用JMeter的BeanShell去获取复杂的JSON串中的某个参数的值,这将 便于我们用JMeter做出更完美的自动化测试: 首先有这样一个json串: { &quo ...
 - jwt手动生成access_token
			
from rest_framework_jwt.settings import api_settings # 手动为用户生成tokenjwt_payload_handler = api_setting ...
 - echarts 柱状图下钻功能
			
var drillDown = { getOption : function () { var option = null; option = { title: { text: ' ...
 - 机器学习框架Tensorflow数字识别MNIST
			
SoftMax回归 http://ufldl.stanford.edu/wiki/index.php/Softmax%E5%9B%9E%E5%BD%92 我们的训练集由 个已标记的样本构成: ,其 ...
 - CentOS6.5下搭建LAMP环境(源码编译方式)
			
CentOS 6.5安装配置LAMP服务器(Apache+PHP5+MySQL) 学习PHP脚本编程语言之前,必须先搭建并熟悉开发环境,开发环境有很多种,例如LAMP ,WAMP,MAMP等.这里我介 ...
 - C++ 虚函数的内存分配
			
1.无继承的普通类: 在有虚函数的情况下类会为其增加一个隐藏的成员,虚函数表指针,指向一个虚函数表,虚函数表里面就是类的各个虚函数的地址了.那么,虚函数表指针是以什么模型加入到类里面的,虚函数表里 ...
 - 实用JS系列——BOM常用对象
			
背景: 最近在着手项目的时候,意识到自己JS的欠缺.虽然看了不少JavaScript的视频,但真正项目中并不是经常遇到大且难的例子.所以JavaScript的基础还需要再打扎实,也就有了这一系列博客 ...
 - web自动化测试:watir+minitest(五)
			
测试报告: 加载minitest-reporters库,并设置相关的参数.既可以在每次运行测试后生成响应的测试报告. 默认会生成一份html的报告在当前目录的test目录下 我们可以指定参数对报告的标 ...
 - [中山市选2011][bzoj2440] 完全平方数 [二分+莫比乌斯容斥]
			
题面 传送门 思路 新姿势get 莫比乌斯容斥 $\sum_{i=1}{n}\mu(i)f(i)$ 这个东西可以把所有没有平方质因子的东西表示出来,还能容斥掉重复的项 证明是根据莫比乌斯函数的定义,显 ...
 - [poj] 3977 Subset || 折半搜索MITM
			
原题 给定N个整数组成的数列(N<=35),从中选出一个子集,使得这个子集的所有元素的值的和的绝对值最小,如果有多组数据满足的话,选择子集元素最少的那个. n<=35,所以双向dfs的O( ...