AC自己主动机 总结

AC自己主动机 总结

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

模板–参考六如家培训指南

/*===============================*\
依照训练指南写的
\*===============================*/
#include<cstring>
#include<queue>
#include<cstdio>
#include<map>
#include<string>
using namespace std;

const int SIGMA_SIZE = 26;
const int MAXNODE = 11000;
const int MAXS = 150 + 10;

map<string,int> ms;

struct AhoCorasickAutomata {
  int ch[MAXNODE][SIGMA_SIZE];
  int f[MAXNODE];    // fail函数
  int val[MAXNODE];  // 每一个字符串的结尾结点都有一个非0的val
  int last[MAXNODE]; // 输出链表的下一个结点
  int cnt[MAXS];
  int sz;

  void init() {
    sz = 1;
    memset(ch[0], 0, sizeof(ch[0]));
    memset(cnt, 0, sizeof(cnt));
    ms.clear();
  }
  inline void clear(){memset(cnt,0,sizeof(cnt));}//假设text不仅仅是一个的话,常常须要每次find都清空一次cnt数组
  // 字符c的编号
  inline int idx(char c) {
    return c-'a';
    //这里一定小心,假设没有给定字符范围的话。直接return c;
    //由于可能出现负的...病毒侵袭那题就是
  }

  // 插入字符串。

v必须非0 void insert(char *s, int v) { int u = 0, n = strlen(s); for(int i = 0; i < n; i++) { int c = idx(s[i]); if(!ch[u][c]) { memset(ch[sz], 0, sizeof(ch[sz])); val[sz] = 0; ch[u][c] = sz++; } u = ch[u][c];//u是下一个节点所存储的ch第一维的位置,相当于我trie中的nxt } val[u] = v; //v是附加信息,最好区分开每一个单词这样 //cnt能够记录出现了哪些以及出现了几次 ms[string(s)] = v; } // 递归打印以结点j结尾的全部字符串 void print(int j) { if(j) { cnt[val[j]]++;//val[j]为单词的编号。ms存储了编号和单词的相应,能够用于打印单词 print(last[j]); } } // 在T中找模板 int find(char* T) { int n = strlen(T); int j = 0; // 当前结点编号,初始为根结点 for(int i = 0; i < n; i++) { // 文本串当前指针 int c = idx(T[i]); while(j && !ch[j][c]) j = f[j]; // 顺着细边走,直到能够匹配 j = ch[j][c]; if(val[j]) print(j);//到单词结尾 else if(last[j]) print(last[j]); // 找到了! } } // 计算fail函数 void getFail() { queue<int> q; f[0] = 0; // 初始化队列 for(int c = 0; c < SIGMA_SIZE; c++) { int u = ch[0][c]; if(u) { f[u] = 0; q.push(u); last[u] = 0; } }//由于第一个字符不匹配须要又一次匹配, //所以第一个字符都指向root(root是Trie入口,没有实际含义) //就是说全部单词第一个字符的f[]都等于0。把节点e的fail指针指向root表示没有匹配序列 // 按BFS顺序计算fail while(!q.empty()) { int r = q.front(); q.pop(); for(int c = 0; c < SIGMA_SIZE; c++) { int u = ch[r][c]; if(!u) continue; q.push(u); int v = f[r]; while(v && !ch[v][c]) v = f[v];//ch[v][c]==0的时候,就是说没有继续能够匹配的字母边了。也是没法继续匹配了,所以继续沿失配函数走 f[u] = ch[v][c]; last[u] = val[f[u]] ? f[u] : last[f[u]]; //last[j] 节点j沿着适配指针往回走时,遇到的下一个单词结点编号 //last是为了解决找到一个单词之后,看看有没有其它串包括 } } }};AhoCorasickAutomata ac;

1、看一个范围内的字符,变化SIGMA_SIZE以及idx功能

版权声明:本文博客原创文章,博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117740.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月1日 上午9:00
下一篇 2022年1月1日 上午9:00


相关推荐

  • homebrew安装

    homebrew安装homebrew

    2026年3月19日
    1
  • 通过JS给HTML元素增加、删除和获取属性内容

    通过JS给HTML元素增加、删除和获取属性内容

    2021年11月10日
    47
  • return 、break和continue的区别和作用

    return 、break和continue的区别和作用return、break和continue的区别和作用1.return关键字并不是专门用于跳出循环的,return的功能是结束一个方法。一旦在循环体内执行到一个return语句,return语句将会结束该方法,循环自然也随之结束。与continue和break不同的是,return直接结束整个方法,不管这个return处于多少层循环之内。publicclassReturnT

    2022年5月1日
    39
  • JMH微基准测试入门案例

    JMH微基准测试入门案例JMH-javaMicrobenchmarkHarness微基准测试,他是测试某个方法的性能到底是好还是不好。这个测试框架是2013年发出来的,有JLT开发人员开发,后来归到OpenJDK下面。官网:http://openjdk.java.net/projects/code-tools/jmh/下面介绍什么是JMH,他是用来干什么的,怎么使用?基于idea中使用。创建…

    2022年7月11日
    22
  • Consul + fabio 实现自动服务发现、负载均衡

    Consul + fabio 实现自动服务发现、负载均衡目录 ConsulFabio 服务发现的特点工作原理 Demo 结合 kubernetes 扩容 nbsp Consulhashic 团队开发就是大名鼎鼎开发 vagrant 的团队 Consul nbsp 是一个提供服务发现 健康检测 K V 存储支持分布式高可用多数据中心的服务软件 比较类似 ZooKeeper 但又比它多了一些功能 具体可以参考 nbsp Consul 和 ZooKeeper 的区别

    2026年3月19日
    2
  • Java–重新认识八种基本数据类型,以后入职不给公司大佬挖坑

    Java–重新认识八种基本数据类型,以后入职不给公司大佬挖坑欢迎进来学习的小伙伴 学习背景 相信很多初学 Java 的小伙伴或者已经入行的 xdm 必然了解 Java 的八种基本数据类型 Java 的数据类型主要分为引用数据类型和基本数据类型 引用数据类型就是平时大家说的万物皆对象 Object 而基本数据类型 对应的有八种 大家应该都记得 也可能不知道或者记不全了 哈哈哈 如果你是 Java 初学者 那么当你去面试 Java 初级工程师的时候 面试官可能会比较喜欢问这个问题 主要是想考察小伙伴们对基本数据类型了解多少 写代码时会不会乱用基本数据类型 给公司的大佬们挖坑 哈哈哈

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号