目录 Trie字典树 KMP AC自动机 Manacher 回文自动机 后缀数组 后缀自动机 ___ Trie字典树 概念 我们先来看看什么是Trie字典树 可以发现,这棵树的每一条边都有一个字符 有一些点是黄色的,表示它们被标记了 那么,哪些字符串在这棵树中出现过呢? 从树的根节点到每一个被标记的 ...
分类:
其他好文 时间:
2020-01-28 23:35:40
阅读次数:
138
参考链接:https://www.acwing.com/solution/acwing/content/2286/ 主串是”ababaeaba”,模式串是”ababacd”,在暴力算法中,遇到不匹配的情况是这样处理的: main: "ababaeaba" // 例如这两个串,当sub为"ababae ...
分类:
编程语言 时间:
2020-01-26 20:59:03
阅读次数:
61
AcWing 831. KMP字符串 https://www.acwing.com/problem/content/833/ 给定一个模式串S,以及一个模板串P,所有字符串中只包含大小写英文字母以及阿拉伯数字。 模板串P在模式串S中多次作为子串出现。 求出模板串P在模式串S中所有出现的位置的起始下标 ...
分类:
编程语言 时间:
2020-01-25 15:36:14
阅读次数:
62
图解AC自动机 前言: + 我们引出这样一个问题: + 我想知道字符串$t$在字符串中$s$出现多少次/有没有出现? + 那我们可以使用kmp算法求出$t$的next数组,之后$O(n)$匹配求解即可。 + 那如果把问题升级一下呢? + 想知道字符串$t_1,t_2,...,t_n$在字符串$s$中 ...
分类:
其他好文 时间:
2020-01-24 09:15:34
阅读次数:
77
oiwiki上讲的挺详细的,但是感觉跟国内不太一样?代码好像也更简短? void pre_ekmp(char s[], int ekmp[], int n) { ekmp[0] = n; //国内是这样用的,oiwiki上好像是定义为0 for (int i = 1, l = 0, r = 0; i ...
分类:
其他好文 时间:
2020-01-23 15:35:06
阅读次数:
104
给定一个模式串S,以及一个模板串P,所有字符串中只包含大小写英文字母以及阿拉伯数字。 模板串P在模式串S中多次作为子串出现。 求出模板串P在模式串S中所有出现的位置的起始下标。 输入格式 第一行输入整数N,表示字符串P的长度。 第二行输入字符串P。 第三行输入整数M,表示字符串S的长度。 第四行输入 ...
分类:
其他好文 时间:
2020-01-22 22:21:12
阅读次数:
75
https://blog.csdn.net/v_july_v/article/details/7041827这篇博客炒鸡详细,其中“next 数组相当于“最大长度值” 整体向右移动一位,然后初始值赋为-1”算是彻底点醒了我,“最大长度值”其实就是前缀函数,OIwiki上的那个定义有误,不过数学公式是 ...
分类:
编程语言 时间:
2020-01-22 22:12:52
阅读次数:
103
一、前言 暴力匹配(Brute Force Match) 是字符串匹配算法里最基础的算法,虽然效率比较低,但胜在方便理解,在小规模数据或对时间无严格要求的情况下可以考虑。 二、代码 C include include int bf(char l,char s); int main(void) { c ...
分类:
编程语言 时间:
2020-01-22 16:39:56
阅读次数:
143
上一篇文章已经写过了,人工智能的发展不可谓不曲折,三起两落,不同的历史阶段,主流的研究方法不一样,开始时的 if else 结构,简单的逻辑判断字符串匹配,到后期的穷举计算等,慢慢发展到现在的大数据与深度学习相结合的主流研究方法,逐渐体现出了较大的优势,同时也涌现出了不同的深度学习(机器学习)框架, ...
分类:
其他好文 时间:
2020-01-21 18:13:18
阅读次数:
90
很久很久以前,在你刚刚学习字符串匹配的时候,有两个仅包含小写字母的字符串A和B,其中A串长度为m,B串长度为n。可当你现在再次碰到这两个串时,这两个串已经老化了,每个串都有不同程度的残缺。
你想对这两个串重新进行匹配,其中A为模板串,那么现在问题来了,请回答,对于B的每一个位置i,从这个位置开始连续... ...
分类:
其他好文 时间:
2020-01-20 21:05:40
阅读次数:
73