博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ.2938.[POI2000]病毒(AC自动机)
阅读量:4351 次
发布时间:2019-06-07

本文共 784 字,大约阅读时间需要 2 分钟。

\(Description\)

给n个模式串,问是否存在长度无限的主串,使得任何一个模式串都没有在主串中出现。

\(Solution\)

先建AC自动机。

假设我们有了一个无限长的安全代码,然后在AC自动机上匹配应该发生什么?
应该是匹配到一个位置失败跳回去,之后要再匹配到这个位置(必须跳回当前链)再失败跳回去。跳回去就是通过fail指针。
Trie树上连上fail指针的边后(其实就是Build时改的son),如果能在这个有向图上找到环,就TAK。
或者,安全代码无限长的话前后要能拼起来,即前后缀相同(同样要跳回当前链),且保证在这过程中不会匹配任何模式串。
前后缀相同就是通过fail指针跳回去(到当前链)。
建图(就是建AC自动机),DFS一遍就可以。注意如果fail[x]匹配,那么x也匹配。
注意访问过的点就没必要再访问了。

这题感觉理解不能,感觉AC自动机在从头开始学。。

//1408kb    72ms#include 
#include
#include
#include
const int N=30005;struct AC_Automaton{ int tot,son[N][2],q[N],fail[N]; bool ed[N],vis[N],ins[N]; char s[N]; void Insert() { scanf("%s",s); int l=strlen(s),x=0; for(int i=0,v; i

转载于:https://www.cnblogs.com/SovietPower/p/9607235.html

你可能感兴趣的文章
Flash动画播放
查看>>
springmvc+mybatis+dubbo+zookeeper 分布式架构
查看>>
HDUOJ-----Computer Transformation
查看>>
HDUOJ-----2838Cow Sorting(组合树状数组)
查看>>
自定义控件之---抽屉式弹窗控件.
查看>>
一款纯css3实现的机器人看书动画效果
查看>>
加班与效率
查看>>
轻量级Modal模态框插件cta.js
查看>>
MyEclipse下SpringBoot+JSP整合过程及踩坑
查看>>
重定向和管道
查看>>
实验五
查看>>
STL学习笔记(第二章 C++及其标准程序库简介)
查看>>
Operator_countByValue
查看>>
Java 日期往后推迟n天
查看>>
Web应用漏洞评估工具Paros
查看>>
Git 和 Github 使用指南
查看>>
20180925-4 单元测试
查看>>
mysql的数据存储
查看>>
[转载] Activiti Tenant Id 字段释疑
查看>>
[Java 8] (8) Lambda表达式对递归的优化(上) - 使用尾递归 .
查看>>