http://172.20.6.3/Problem_Show.asp?id=1369

trie树如果不优化就这么往里面放这么多单词肯定超空间+超时,所以需要去掉无用的字符串(不属于原字符串的),但是一个一个判断时间又很长;

所以解决方案就是用一个多维vis数组胡搞判定一下,非常魔性。。。

代码

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
using namespace std;
const long long maxn=;
const int modn=;
int n,m;
char ch[maxn]={};
char ch1[]={};
int vis[maxn]={};
queue<int>q;
struct trie{
int next[];
bool exist;
int fail,d;
}e[maxn*];int tot=;
bool ff[][][][][]={};
void insert(int k,int d,int x){
if(d==k){
e[x].exist=;e[x].d=d;
return;
}
int z=ch1[d]-'a';
if(!e[x].next[z])e[x].next[z]=++tot;
insert(k,d+,e[x].next[z]);
}
void build(){
q.push();int x,y,f;
while(!q.empty()){
x=q.front();q.pop();
for(int i=;i<;i++){
y=e[x].next[i];
if(y){
if(x!=){
f=e[x].fail;
while((!e[f].next[i])&&f)f=e[f].fail;
e[y].fail=e[f].next[i];
}q.push(y);
}
}
}
}
int read(){
char chh=getchar();int k=;
while(chh<'a'||chh>'z'){chh=getchar();}
while(chh>='a'&&chh<='z'){ch1[k++]=chh;chh=getchar();}
return k;
}
void read1(){
char chh=getchar();int k=;
while(chh<'a'||chh>'z'){chh=getchar();}
while(chh>='a'&&chh<='z'){ch[k++]=chh;chh=getchar();}
}
int main(){
//freopen("wtf.in","r",stdin);
//freopen("wtf.out","w",stdout);
scanf("%d",&n);read1();
for(int i=;i<n;i++){
ff[(int)ch[i-]-'a'][(int)ch[i-]-'a'][(int)ch[i-]-'a'][(int)ch[i-]-'a'][(int)ch[i]-'a']=;
}
scanf("%d",&m);
for(int i=;i<=m;i++){
int siz=read(),wtf=;
for(int j=;j<siz;j++){
if(!ff[(int)ch1[j-]-'a'][(int)ch1[j-]-'a'][(int)ch1[j-]-'a'][(int)ch1[j-]-'a'][(int)ch1[j]-'a'])
wtf=;
}if(wtf)insert(siz,,);
}build();
int x=,y;
for(int i=;i<n;i++){
int z=ch[i]-'a';
while((!e[x].next[z])&&x){
x=e[x].fail;
}
x=e[x].next[z];y=x;
while((!e[y].exist)&&y){
y=e[y].fail;
}vis[i-e[y].d+]=max(vis[i-e[y].d+],e[y].d);
}
int k=;int t=;
for(int i=;i<n;i++){
k=max(vis[i],k);
if(k>)t++;
k--;
}
printf("%d\n",n-t);
return ;
}

JZYZOJ1369 [coci2012]覆盖字符串 AC自动机的更多相关文章

  1. [coci2012]覆盖字符串 AC自动机

    给出一个长度为N的小写字母串,现在Mirko有M个若干长度为Li字符串.现在Mirko要用这M个字符串去覆盖给出的那个字符串的.覆盖时,必须保证:1.Mirko的字符串不能拆开,旋转:2.Mirko的 ...

  2. 模板—字符串—AC自动机(多模式串,单文本串)

    模板—字符串—AC自动机(多模式串,单文本串) Code: #include <queue> #include <cstdio> #include <cstring> ...

  3. 【bzoj1030】: [JSOI2007]文本生成器 字符串-AC自动机-DP

    [bzoj1030]: [JSOI2007]文本生成器 首先把匹配任意一个的个数的问题转化为总个数-没有一个匹配的个数 先构造AC自动机,然后枚举每一位的字母以及在自动机上的位置 f[i][j]为第i ...

  4. 【bzoj3172】: [Tjoi2013]单词 字符串-AC自动机

    [bzoj3172]: [Tjoi2013]单词 先用所有单词构造一个AC自动机 题目要求的是每个单词在这个AC自动机里匹配到的次数 每次insert一个单词的时候把路径上的cnt++ 那么点p-&g ...

  5. 字符串——AC自动机

    目录 一.前言 二.思路 三.代码 四.参考资料 一.前言 以前一直没学AC自动机,主要是被名字吓到了,自动AC,这么强的名字肯定很难,学了后才发现,其实不难. AC自动机并不是Acept autom ...

  6. 【bzoj2434】: [Noi2011]阿狸的打字机 字符串-AC自动机-BIT

    [bzoj2434]: [Noi2011]阿狸的打字机 x串在y串上的匹配次数就是y在自动机所有节点上能够通过fail走到x最后一个节点的个数 (就是y串任意一个前缀的后缀能匹配到x的个数)和[bzo ...

  7. bzoj 3172 单词 ac自动机|后缀数组

    题目大意: 给定n个字符串连成了一篇文章,问每个字符串在这篇文章中出现的次数,可重复覆盖 这里ac自动机和后缀数组都可以做 当然后缀数组很容易就解决,但是相对时间消耗高 这里就只讲ac自动机了 将每个 ...

  8. AC自动机相关Fail树和Trie图相关基础知识

    装载自55242字符串AC自动机专栏 fail树 定义 把所有fail指针逆向,这样就得到了一棵树 (因为每个节点的出度都为1,所以逆向后每个节点入度为1,所以得到的是一棵树) 还账- 有了这个东西, ...

  9. 「kuangbin带你飞」专题十七 AC自动机

    layout: post title: 「kuangbin带你飞」专题十七 AC自动机 author: "luowentaoaa" catalog: true tags: - ku ...

随机推荐

  1. 【TYVJ】P1039 忠诚2

    [算法]线段树 [注意]修改或查询区间时,若区间能包含某棵子树就立即返回,否则线段树就失去了意义. #include<cstdio> #include<algorithm> u ...

  2. 【51NOD-5】1293 球与切换器

    [算法]DP [题解]f[i][j][0]表示在i,j位置往下走的球数,f[i][j][1]表示在i,j位置往右走的球数,经过i,j的球若为-1则(num+1)/2往下,其余往右.+1类似. 转移见代 ...

  3. HDU 2553 N皇后问题 (深搜)

    题目链接 Problem Description 在N*N的方格棋盘放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在与棋盘边框成45角的斜线上. 你的任务是,对 ...

  4. .net JsonHelper json帮助类

    using Newtonsoft.Json; using System.Runtime.Serialization.Json; using System.Text; public class Json ...

  5. lnmp、lamp、lnmpa一键安装包(Updated: 2016-4-12)

    lnmp.lamp.lnmpa一键安装包(Updated: 2016-4-12)   文章目录 脚本特性 安装步骤 如何添加虚拟主机? 如何删除虚拟主机? 如何管理ftp账号? 数据备份 如何管理服务 ...

  6. Spark-2.3.2【SparkStreaming+SparkSQL-实时仪表盘应用】

    应用场景:实时仪表盘(即大屏),每个集团下有多个mall,每个mall下包含多家shop,需实时计算集团下各mall及其shop的实时销售分析(区域.业态.店铺TOP.总销售额等指标)并提供可视化展现 ...

  7. upupw注入by pass

    http:' and updatexml(null,concat(0x5c,(/*!00000select SCHEMA_name*/from/*!information_schema*/.schem ...

  8. 通过call_usermodehelper()在内核态执行用户程序【转】

    转自:http://edsionte.com/techblog/archives/category/linux%E5%86%85%E6%A0%B8%E7%BC%96%E7%A8%8B 背景 如何在Li ...

  9. 终于解决了Linux下运行OCCI程序一直报Error while trying to retrieve text for error ORA-01804错误

    终于解决了Linux下运行OCCI程序一直报Error while trying to retrieve text for error ORA-01804错误 http://blog.csdn.net ...

  10. 33.Search in Rotated Sorted Array---二分变形---《剑指offer》面试题8

    题目链接 题目大意:在一个旋转数组中,判断给定的target是否存在于该旋转数组中.数组中没有重复数值.例子如下: 法一:二分.确定中间元素之后,就要判断下一步是遍历左数组还是遍历右数组.如果左数组有 ...