热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

P3796AC自动机强化版题解-Aho-CorasickAlgorithm

本文提供了一个关于AC自动机(Aho-CorasickAlgorithm)的详细解析与实现方法,特别针对P3796题目进行了深入探讨。文章不仅涵盖了AC自动机的基本概念,还重点讲解了如何通过构建失败指针(failpointer)来提高字符串匹配效率。

题目链接


P3796 AC自动机强化版题解 - Aho-Corasick Algorithm


解题思路


本题旨在通过AC自动机解决多模式串匹配问题。AC自动机是一种高效的字符串匹配算法,它能够在O(n + m)的时间复杂度内完成模式串的预处理和文本串的搜索,其中n是所有模式串的总长度,m是文本串的长度。


AC自动机的核心在于失败指针(fail pointer)的构建。失败指针用于在当前路径无法继续匹配时,快速跳转至一个可能的匹配起点,从而避免重复扫描文本串。具体来说,当在某个节点上匹配失败时,失败指针会指向一个能够继续匹配的节点,该节点对应的字符串是当前节点前缀的最大公共后缀。


AC代码


#include 
#include

#define MAXN 100010
#define MAXM 1000010
#define MAXL 75

int ac[MAXN][26], cnt = 1;
int queue[MAXN], fail[MAXN], end[MAXN];
char patterns[MAXL][MAXL], text[MAXM];

struct Result {
int index, count;
} results[500], temp;

void insertPattern(const char *pattern, int length, int index) {
int node = 0;
for (int i = 0; i int c = pattern[i] - 'a';
if (!ac[node][c]) ac[node][c] = cnt++;
node = ac[node][c];
}
end[node] = index;
}

void buildFailPointers() {
int head = 0, tail = 0;
for (int i = 0; i <26; ++i) {
if (ac[0][i]) {
queue[tail++] = ac[0][i];
fail[ac[0][i]] = 0;
}
}
while (head int current = queue[head++];
for (int i = 0; i <26; ++i) {
if (ac[current][i]) {
fail[ac[current][i]] = ac[fail[current]][i];
queue[tail++] = ac[current][i];
} else {
ac[current][i] = ac[fail[current]][i];
}
}
}
}

void searchText(const char *text, int length) {
int node = 0;
for (int i = 0; i node = ac[node][text[i] - 'a'];
for (int j = node; j; j = fail[j]) {
if (end[j]) {
results[end[j]].count++;
}
}
}
}

int compare(const void *a, const void *b) {
return ((Result *)b)->count - ((Result *)a)->count;
}

int main() {
int n;
while (scanf("%d", &n) != EOF && n) {
cnt = 1;
for (int i = 1; i <= n; ++i) {
scanf("%s", patterns[i]);
insertPattern(patterns[i], strlen(patterns[i]), i);
results[i].index = i;
results[i].count = 0;
}
buildFailPointers();
scanf("%s", text);
searchText(text, strlen(text));
qsort(results + 1, n, sizeof(Result), compare);
printf("%d\n", results[1].count);
printf("%s\n", patterns[results[1].index]);
for (int i = 2; i <= n; ++i) {
if (results[i].count != results[i - 1].count) break;
printf("%s\n", patterns[results[i].index]);
}
memset(end, 0, sizeof(int) * cnt);
memset(fail, 0, sizeof(int) * cnt);
memset(ac, 0, sizeof(ac));
}
return 0;
}

推荐阅读
  • LeetCode 102 - 二叉树层次遍历详解
    本文详细解析了LeetCode第102题——二叉树的层次遍历问题,提供了C++语言的实现代码,并对算法的核心思想和具体步骤进行了深入讲解。 ... [详细]
  • 本报告记录了嵌入式软件设计课程中的第二次实验,主要探讨了使用KEIL V5开发环境和ST固件库进行GPIO控制及按键响应编程的方法。通过实际操作,加深了对嵌入式系统硬件接口编程的理解。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 本文介绍了用户界面(User Interface, UI)的基本概念,以及在iOS应用程序中UIView及其子类的重要性和使用方式。文章详细探讨了UIView如何作为用户交互的核心组件,以及它与其他UI控件和业务逻辑的关系。 ... [详细]
  • 本文探讨了线性表中元素的删除方法,包括顺序表和链表的不同实现策略,以及这些策略在实际应用中的性能分析。 ... [详细]
  • 本文由chszs撰写,详细介绍了Apache Mina框架的核心开发流程及自定义协议处理方法。文章涵盖从创建IoService实例到协议编解码的具体步骤,适合希望深入了解Mina框架应用的开发者。 ... [详细]
  • 深入解析Unity3D游戏开发中的音频播放技术
    在游戏开发中,音频播放是提升玩家沉浸感的关键因素之一。本文将探讨如何在Unity3D中高效地管理和播放不同类型的游戏音频,包括背景音乐和效果音效,并介绍实现这些功能的具体步骤。 ... [详细]
  • 本文探讨了一种常见的C++面试题目——实现自己的String类。通过此过程,不仅能够检验开发者对C++基础知识的掌握程度,还能加深对其高级特性的理解。文章详细介绍了如何实现基本的功能,如构造函数、析构函数、拷贝构造函数及赋值运算符重载等。 ... [详细]
  • 本文探讨了使用普通生成函数和指数生成函数解决组合与排列问题的方法,特别是在处理特定路径计数问题时的应用。文章通过详细分析和代码实现,展示了如何高效地计算在给定条件下不相邻相同元素的排列数量。 ... [详细]
  • 实现Win10与Linux服务器的SSH无密码登录
    本文介绍了如何在Windows 10环境下使用Git工具,通过配置SSH密钥对,实现与Linux服务器的无密码登录。主要步骤包括生成本地公钥、上传至服务器以及配置服务器端的信任关系。 ... [详细]
  • JavaScript 中引号的多层嵌套使用技巧
    本文详细介绍了在 JavaScript 编程中如何处理引号的多级嵌套问题,包括双引号、单引号以及转义字符的正确使用方法。 ... [详细]
  • 本文详细介绍如何在SSM(Spring + Spring MVC + MyBatis)框架中实现分页功能。包括分页的基本概念、数据准备、前端分页栏的设计与实现、后端分页逻辑的编写以及最终的测试步骤。 ... [详细]
  • 解决UIScrollView自动偏移问题的方法
    本文介绍了一种有效的方法来解决在使用UIScrollView时出现的自动向下偏移的问题,通过调整特定的属性设置,可以确保滚动视图正常显示。 ... [详细]
  • 如何高效渲染JSON数据
    本文介绍了在控制器中返回JSON结果的方法,并详细说明了如何利用jQuery处理和展示这些数据,为Web开发提供了实用的技巧。 ... [详细]
  • 探索Java 11中的ZGC垃圾收集器
    Java 11引入了一种新的垃圾收集器——ZGC,由Oracle公司研发,旨在支持TB级别的内存容量,并保证极低的暂停时间。本文将探讨ZGC的开发背景、技术特点及其潜在的应用前景。 ... [详细]
author-avatar
陈芝麻烂谷子我勒个去
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有