博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ 3940 AC自动机
阅读量:6156 次
发布时间:2019-06-21

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

思路:

需要维护一个栈的AC自动机…….
要求出来 最后的栈顶是在自动机上的哪个节点。

if(!ac.ch[st[tp-1]][a[i]-'a']) st[tp]=ac.ch[ac.f[st[tp-1]]][a[i]-'a'];else st[tp]=ac.ch[st[tp-1]][a[i]-'a'];

如果ch[][] 到不了根 就要走到fail

//By SiriusRen#include 
#include
#include
#include
using namespace std;#define N 500050#define M 26int n,st[100050],tp=0;char a[100050],jy[100500];struct AC_Automata{ int sz,ch[N][M],f[N],len[N]; void insert(char s[],int num){ int u=0,i; for(i=0;s[i];i++){ if(!ch[u][s[i]-'a'])ch[u][s[i]-'a']=++sz; u=ch[u][s[i]-'a']; } len[u]=i; } void build(){ f[0]=500000; queue
q;q.push(0); while(!q.empty()){ int r=q.front();q.pop(); for(int i=0;i

转载于:https://www.cnblogs.com/SiriusRen/p/6532154.html

你可能感兴趣的文章
android apk 逆向中常用工具一览
查看>>
MyEclipse 报错 Errors running builder 'JavaScript Validator' on project......
查看>>
Skip List——跳表,一个高效的索引技术
查看>>
Yii2单元测试初探
查看>>
五、字典
查看>>
前端js之JavaScript
查看>>
Log4J日志配置详解
查看>>
实验7 BindService模拟通信
查看>>
scanf
查看>>
Socket编程注意接收缓冲区大小
查看>>
SpringMVC初写(五)拦截器
查看>>
检测oracle数据库坏块的方法
查看>>
SQL server 安装教程
查看>>
Linux下ftp和ssh详解
查看>>
跨站脚本功攻击,xss,一个简单的例子让你知道什么是xss攻击
查看>>
js时间和时间戳之间如何转换(汇总)
查看>>
js插件---图片懒加载echo.js结合 Amaze UI ScrollSpy 使用
查看>>
java中string和int的相互转换
查看>>
P1666 前缀单词
查看>>
HTML.2文本
查看>>