AC自动机自我理解和模板
给出长度为m的文本
查询 n个单词出现的次数
用kmp 复杂度 n*m*(单词平均长度)
用字典树 复杂度 m*每次字典树遍历的平均深度)
AC自动机 复杂度 m (思路可以理解为kmp+字典树 )
正在学 代码没修改完
#include<bits/stdc++.h> using namespace std; ; ; struct node { node *fail; node *next[kind]; int cnt; node() { fail=NULL; cnt=; memset(next,NULL,sizeof(next)); } }*q[maxn]; ]; ]; //模式串 int head,tail; //队列的头尾指针 void insert(char *str,node *root) // **************建树 { node *p=root; ,index; while(str[i]) { index=str[i]-'a'; if(p->next[index]==NULL) p->next[index]=new node(); p=p->next[index]; i++; }p->cnt++; } void build_ac_automation(node *root) { root->fail=NULL; q[head++]=root;// tou zhi zheng while(head!=tail) { node *temp=q[tail++]; node *p=NULL; ;i<;i++) { if(temp->next[i]!=NULL) { if(temp==root) temp->next[i]->fail=root; else { p=temp->fail; while(p!=NULL) { if(p->next[i]!=NULL) { temp->next[i]->fail=p->next[i]; break; } p=p->fail; } if(p==NULL) temp->next[i]->fail=root; } q[head++]=temp->next[i]; } } } } int ac_query(node *root) { ; ; int index; int l=strlen(str); node *p=root; while(str[i]) { index=str[i]-'a'; index=str[i]-'a'; while(p->next[index]==NULL && p!=root) p=p->fail; p=p->next[index]; p=(p==NULL)?root:p; node *temp=p; ) { num+=temp->cnt; temp->cnt=-; temp=temp->fail; } i++; } return num; } int32_t main() { }
banzi https://www.cnblogs.com/MingSD/p/8733762.html
#include<bits/stdc++.h> using namespace std; #define LL long long #define ULL unsigned LL #define fi first #define se second #define lson l,m,rt<<1 #define rson m+1,r,rt<<1|1 #define max3(a,b,c) max(a,max(b,c)) #define min3(a,b,c) min(a,min(b,c)) const int INF = 0x3f3f3f3f; ; typedef pair<int,int> pll; , M = 1e3; ]; ][]; ]; ]; ; void Insert(){ , len = strlen(str); ; i < len; i++){ int id = str[i] - 'a'; ){ cnt[tot] = ; fair[tot] = ; trie[rt][id] = tot++; } rt = trie[rt][id]; } cnt[rt]++; } void Build_tree(){ queue<int> q; q.push(); int p; while(!q.empty()){ int tmp = q.front(); q.pop(); ; i < ; i++){ ){ ) fair[trie[tmp][i]] = ; else{ p = fair[tmp]; while(p){ if(trie[p][i]){ fair[trie[tmp][i]] = trie[p][i]; break; } else p = fair[p]; } ; } q.push(trie[tmp][i]); } } } } int Query(){ , ret = , len = strlen(str); ; i < len; i++){ int id = str[i] - 'a'; ) rt = fair[rt]; rt = trie[rt][id]; ) rt = ; int tmp = rt; ){ ){ ret += cnt[tmp]; cnt[tmp] = -; } else break; tmp = fair[tmp]; } } return ret; } void init(){ ; i < tot; i++){ ; j < ; j++) trie[i][j] = ; } tot = ; } int main(){ int T; scanf("%d", &T); while(T--) { init(); int n; scanf("%d", &n); while(n--) { scanf("%s", str); Insert(); } Build_tree(); scanf("%s", str); printf("%d\n", Query()); } ; }
AC自动机自我理解和模板的更多相关文章
- AC自动机详解 (P3808 模板)
AC自动机笔记 0.0 前言 哇,好久之前就看了 KMP 和 Trie 树,但是似乎一直没看懂 AC自动机?? 今天灵光一闪,加上之前看到一些博客和视频,瞬间秒懂啊... 其实这个玩意还是蛮好理解的. ...
- HDOJ-2222(AC自动机+求有多少个模板串出现在文本串中)
Keywords Search HDOJ-2222 本文是AC自动机的模板题,主要是利用自动机求有多少个模板出现在文本串中 由于有多组输入,所以每组开始的时候需要正确的初始化,为了不出错 由于题目的要 ...
- KMP算法自我理解 和 模板
字符串 abcd abc abcd abc 匹配串 cdabcd 匹配串的 next 0 0 0 0 1 2: 开始匹配 abcd abc abcd abc cd abc d a,d 匹配失 ...
- 【AC自动机】HDU中模板题
[HDU2222] 最纯粹的裸题,错误点详见注释. #include<iostream> #include<cstdio> #include<cstring> #i ...
- ac自动机(tree+kmp模板)
Keywords Search Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others ...
- HDU 2222 AC自动机模板题
题目: http://acm.hdu.edu.cn/showproblem.php?pid=2222 AC自动机模板题 我现在对AC自动机的理解还一般,就贴一下我参考学习的两篇博客的链接: http: ...
- 【题解】P3796【模板】AC自动机(加强版)
[题解]P3796 [模板]AC自动机(加强版) 记录当前\(cnt\)是第几个"星".记录第几个串是对应着第几个星. 这里补充一点对于\(AC\)自动机的理解.可能一直有个问题我 ...
- AC自动机--summer-work之我连模板题都做不出
这章对现在的我来说有点难,要是不写点东西,三天后怕是就一无所有了. 但写这个没有营养的blog的目的真的不是做题或提升,只是学习学习代码和理解一些概念. 现在对AC自动机的理解还十分浅薄,这里先贴上目 ...
- 洛谷--P3808 【模板】AC自动机(“假的“简单版)
如果你想要做出这道题,你需要先了解两个知识点: 1.字典树的构造 2.KMP算法(也就是fail指针的构造) 对于字典树,可以看看这个大佬: https://www.cnblogs.com/TheRo ...
随机推荐
- shlve 模块
shlve 模块 也用于序列化 它与pickle 不同之处在于 不需要惯性文件模式什么的 直接把它当成一个字典来看待 它可以直接对数据进行修改 而不用覆盖原来的数据 而pickle 你想要修改只能 ...
- UVa 3602 - DNA Consensus String 水题 难度: 0
题目 https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_pr ...
- 一些做vue前端的经验
1.先赋值,后渲染 场景:表格渲染中,一般都是这样把json的东西传给table的 this.tableData = json.data.rows 然后的话我们一般会在渲染前对json中的数据做一些转 ...
- Sql Server 中 根据列名查询表名
已知列名 ELEMENT_ID ,查询所属表名称 Select O.name objectName, C.name ColumnName from sys.columns C inner join s ...
- [Leetcode 392]判断子序列 Is Subsequence
[思路] 判断s是否为t的子串,所以length(s)<=length(t).于是两个指针,一次循环. 将s.t转换为数组p1.p2. i为过程中s的匹配长度. i=0空串,单独讨论返回true ...
- 六、在U-boot中让LCD填充纯色
1. 编译U-boot 准备好U-boot压缩包urbetter-u-boot-1.1.6-v1.0.tgz,输入命令:tar -xvf urbetter-u-boot-1.1.6-v1.0.tgz ...
- Android:getContext().getSystemService()
一.介绍 getSystemService是Android很重要的一个API,它是Activity的一个方法,根据传入的NAME来取得对应的Object,然后转换成相应的服务对象 二.语法 Windo ...
- shell脚本实例-for实现批量主机的探测
#!/usr/bin/bash >ip.txt for i in {2..254} do { ip=192.168.234.$i ping -c1 -W1 $ip &>/dev/n ...
- ChinaCock界面控件介绍-CCGridPictureEditor
CCGridPictureEditor如其名,网格图片编辑控件,实现利用一个网格来显示多张图片的缩略图,这是一个非常实用的控件,实现类似微信朋友圈中发布多张图片的功能. 在没有这个控件之前,我都是用D ...
- 在 Andriod/IOS 程序中使用自定义字体
很早就遇到这个问题,QDAC作者也在这里给出了方案.