[洛谷P3121] 审查(黄金) (AC自动机)
题目描述
FJ把杂志上所有的文章摘抄了下来并把它变成了一个长度不超过10^5的字符串S。他有一个包含n个单词的列表,列表里的n个单词记为t_1...t_N。他希望从S中删除这些单词。
FJ每次在S中找到最早出现的列表中的单词(最早出现指该单词的开始位置最小),然后从S中删除这个单词。他重复这个操作直到S中没有列表里的单词为止。注意删除一个单词后可能会导致S中出现另一个列表中的单词
FJ注意到列表中的单词不会出现一个单词是另一个单词子串的情况,这意味着每个列表中的单词在S中出现的开始位置是互不相同的
请帮助FJ完成这些操作并输出最后的S
输入输出格式
Input
第一行包含S.
第二行包含N,即审查出来的单词的数量。
接下来的N行包含字符串t1…tn。每个字符串将只包含小写字母(范围在a...z),并且所有这些字符串的组合长度将最多是10^5。
Output
删除操作完成后形成的新的字符串S(这里保证删除过程中不会出现空串)。
输入输出样例
输入样例#1:
begintheescapexecutionatthebreakofdawn
2
escape
execution
输出样例#1:
beginthatthebreakofdawn
题解思路
看到多个串在一个串上匹配啊是吧,这不AC自动机模板(巨难)题吗。
不过我们是要删除串啊,怎么考虑去删掉这些串呢?
首先这个出题人可能语文是体育老师教的,也许是我的语文是体育老师教的(逃
最早出现的列表中的单词(最早出现指该单词的开始位置最小,这TM不是说我们删单词要一个一个按顺序删,而是说,在文本串里最早出现的一个随便哪一个模式串我们把它删掉
然后怎么搞?
我们考虑把不要删除的文本串一次加入一个栈中,要删掉的那个单词在匹配完成时,再从栈里面弹出之前的单词长度即可。最后输出栈
关于AC自动机在这道题的卵用
我们在字典树上跑文本串的时候,可能某一次文本串匹配单词时,那个字典树的节点是空的,所以用fail指针来节省时间和避免错误
YYJ丑陋的代码系列
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<queue>
using namespace std;
const int N=500001;
struct node{
int fail,ch[26],end;
}t[N];
char SS[N],ss[N],s[N];
int S[N],top,cnt;
void build()
{
int now=0,len=strlen(s);
for(int i=0;i<len;i++)
{
if(!t[now].ch[s[i]-'a'])
t[now].ch[s[i]-'a']=++cnt;
now=t[now].ch[s[i]-'a'];
}
t[now].end=len;
}
void get_fail()
{
queue<int>q;
for(int i=0;i<26;i++)
if(t[0].ch[i])q.push(t[0].ch[i]);
while(!q.empty())
{
int u=q.front();q.pop();
for(int i=0;i<26;i++)
{
if(t[u].ch[i])
t[t[u].ch[i]].fail=t[t[u].fail].ch[i],q.push(t[u].ch[i]);
else t[u].ch[i]=t[t[u].fail].ch[i];
}
}
}
int main()
{
scanf("%s",ss);
int n;scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%s",s);
build();
}
get_fail();
int len=strlen(ss),now=0;
for(int i=0;i<len;i++)
{
++top;
S[top]=now;
SS[top]=ss[i];
now=t[now].ch[ss[i]-'a'];
if(t[now].end)
top-=t[now].end,now=S[top+1];
}
for(int i=1;i<=top;i++)
cout<<SS[i];
return 0;
}
[洛谷P3121] 审查(黄金) (AC自动机)的更多相关文章
- 洛谷P3121 审查(黄金)Censoring(Gold) [USACO15FEB] AC自动机
正解:AC自动机 解题报告: 传送门! 啊我好呆啊其实就挺模板题的,,,只是要一个栈搞一下,,,然后我就不会了,,,是看了题解才get的,,,QAQ 然后写下解法趴QwQ 首先看到多串匹配不难想到AC ...
- 洛谷-P5357-【模板】AC自动机(二次加强版)
题目传送门 -------------------------------------- 过年在家无聊补一下这周做的几道AC自动机的模板题 sol:AC自动机,还是要解决跳fail边产生的重复访问,但 ...
- 洛谷P2444 病毒【AC自动机】
题目描述 二进制病毒审查委员会最近发现了如下的规律:某些确定的二进制串是病毒的代码.如果某段代码中不存在任何一段病毒代码,那么我们就称这段代码是安全的.现在委员会已经找出了所有的病毒代码段,试问,是否 ...
- 洛谷P3966 [TJOI2013]单词(AC自动机)
题目描述 小张最近在忙毕设,所以一直在读论文.一篇论文是由许多单词组成但小张发现一个单词会在论文中出现很多次,他想知道每个单词分别在论文中出现了多少次. 输入输出格式 输入格式: 第一行一个整数N,表 ...
- 洛谷P3966 单词 [TJOI2013] AC自动机
正解:AC自动机 解题报告: 传送门! 先来提供一个40pts错解QAQ 首先看到这题就会想到AC自动机板子题2鸭!然后就照着那题的套路打一下,随便改一点儿,简单来说就是每次经过一个节点都要++,然后 ...
- 洛谷P2444 病毒 [POI2000] AC自动机
正解:AC自动机 解题报告: 传送门! 首先看到这种题目二话不说先把trie树和fail指针建立起来 然后就想鸭,如果我们想让模式串和文本串尽量不能匹配,就要想办法让它跳fail指针,而不是继续往下走 ...
- 洛谷2414(构建ac自动机fail树dfs序后遍历Trie树维护bit及询问答案)
要点 这是一道蔡队题,看我标题行事 任意询问y串上有多少个x串,暴力找每个节点是不是结尾肯定是炸的,考虑本质:如果某节点是x的结尾,根据ac自动机的性质,x一定是此(子)串后缀.又有每个Trie节点的 ...
- 洛谷-P3796-【模板】AC自动机(加强版)
题目传送门 -------------------------------------- 过年在家无聊补一下这周做的几道AC自动机的模板题 sol:AC自动机,在fail边的基础上再加一个last边, ...
- 洛谷.3808/3796.[模板]AC自动机
题目链接:简单版,增强版 简单版: #include <cstdio> #include <cstring> const int N=1e6+5,S=26; char s[N] ...
随机推荐
- (转)PHP(其他语言类似)编码的规范性
为了提高工作效率,保证开发的有效性和合理性,并最大程度提高程序代码的可读性和可重复利用性,提高沟通效率,需要一份代码编辑规范. 一.文件标记: 1.所有php文件 ...
- iOS Device Types
ios 设备硬件名称对照表 https://support.hockeyapp.net/kb/client-integration-ios-mac-os-x-tvos/ios-device-types ...
- Angualr+asp.net core webapi+efcore系列
想着学习一门前端框架,WTF,看了又看,卧槽对于.Net程序员来说,还有什么比面向对象更香的呢,所以果断的选择了Angular.正好看各路大神以及官方文档想学习一下asp.net core,那就搞起吧 ...
- 安卓、safari和微信各个浏览器的设计标准
- Python格式化字符串、占位符、合并数组
合并数组 参考链接:https://www.cnblogs.com/chaihy/p/7243143.html >>> a=[2] >>> b=[3] >&g ...
- debug和release的区别
Debug和Release,主要是针对其面向的目标不同的而进行区分的.Debug通常称为调试版本,通过一系列编译选项的配合,编译的结果通常包含调试信息,而且不做任何优化,以为开发人员提供强大的应用程序 ...
- BZOJ 2683 简单题 cdq分治+树状数组
题意:链接 **方法:**cdq分治+树状数组 解析: 首先对于这道题,看了范围之后.二维的数据结构是显然不能过的.于是我们可能会考虑把一维排序之后还有一位上数据结构什么的,然而cdq分治却可以非常好 ...
- 【HDU-4614】Vases and Flowers(线段树双查询)
11946317 2014-10-23 09:08:28 Accepted 4614 437MS 2348K rid=11946317" target="_blank" ...
- JavaWeb利用cookie记住账号
JavaWeb利用cookie记住账号. 首先,来看看界面什么样子. 记住账号最普遍的做法,就是在点击登录时,将账号保存到cookie中. 材料准备 <script src="${ct ...
- ubuntu 14.04 桌面版关闭图形界面
ubuntu 14.04 桌面版关闭图形界面 问题: 怎样将ubuntu14.04设置为文本模式启动? 解决方式: 改动改GRUB 的配置文件(不建议直接改 grub.conf) $sudo vim ...