题目:

P3121 [USACO15FEB]审查(黄金)Censoring (Gold)

解析:

多字符串匹配,首先想到AC自动机

建立一个AC自动机

因为有删除和拼接这种操作,考虑用栈维护

顺着文本串匹配的方向走,将经过的节点放入栈中,若匹配到一个模式串,就将这个模式串弹出,从栈顶开始继续走

我们再维护一个pos数组,用来维护trie树中节点对应在文本串中的位置

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10; int n, num;
int sta[N], pos[N]; char s[N], t[N]; struct node {
int fail, end;
int nx[26];
} e[N]; inline void TrieInsert(char *s) {
int rt = 0, len = strlen(s);
for (int i = 0; i < len; ++i) {
int v = s[i] - 'a';
if (!e[rt].nx[v]) e[rt].nx[v] = ++num;
rt = e[rt].nx[v];
}
e[rt].end = len;
} queue<int>q;
inline void GetFail() {
for (int i = 0; i < 26; ++i) if (e[0].nx[i]) {
q.push(e[0].nx[i]);
e[e[0].nx[i]].fail = 0;
}
while (!q.empty()) {
int u = q.front();
q.pop();
for (int i = 0; i < 26; ++i) {
if (e[u].nx[i]) {
e[e[u].nx[i]].fail = e[e[u].fail].nx[i];
q.push(e[u].nx[i]);
} else e[u].nx[i] = e[e[u].fail].nx[i];
}
}
} void query(char *s) {
int rt = 0, top = 0, len = strlen(s);
for (int i = 0; i < len; ++i) {
rt = e[rt].nx[s[i] - 'a'];
sta[++top] = rt;
pos[top] = i;
if (e[rt].end) {
top -= e[rt].end;
rt = sta[top];
}
}
for (int i = 1; i <= top; ++i) printf("%c", s[pos[i]]);
putchar('\n');
} int main() {
cin >> t;
cin >> n;
for (int i = 1; i <= n; ++i) {
cin >> s;
TrieInsert(s);
}
GetFail();
query(t);
return 0;
}

最新文章

  1. 继承AppCompatActivity的Activity隐藏标题栏
  2. JAVA类的静态加载和动态加载以及NoClassDefFoundError和ClassNotFoundException
  3. 【003:jsoncpp的简单使用】
  4. 测试markdown
  5. mysql 求最小值/最大值
  6. [译]How to Setup Sync Gateway on Ubuntu如何在ubuntu上安装sync-gateway
  7. IIS 之 HTTP 错误 500.19(无法访问请求页面,因为该页的相关配置数据无效)
  8. 设置mysql密码 Access denied 问题
  9. jQuery 遍历 – 过滤
  10. sudo:无法解析主机
  11. 两个对象的 hashCode()或equals相同,equals或hashCode不一定相同--《案例演示》
  12. 再读vue2.0
  13. Pandas截取列的一部分
  14. BZOJ3817 清华集训2014 Sum 类欧几里得
  15. Luogu2570 [ZJOI2010]贪吃的老鼠 ---- 网络流
  16. mysql索引总结(3)-MySQL聚簇索引和非聚簇索引
  17. 创建类type (底层代码)
  18. [ 转载 ] Mysql 远程连接+开放80和3306端口 常用配置
  19. C++迭代器失效的几种情况总结
  20. django带后台管理功能的网站

热门文章

  1. SQL on Hadoop技术综述
  2. [源码分析]HashSet 和LinkedHashSet
  3. Windows通过URL启动本机App
  4. 带缓存的基于DateTimeFormatter的日期格式化工具类
  5. Default Activity Not Found解决方法
  6. java上传图片并压缩图片大小
  7. 【Base】死锁产生的四个必要条件
  8. layui 复选框checkbox 实现全选全选
  9. Vue基础知识学习笔记
  10. 在Windows平台下使用Gitblit搭建Git服务器图文解说