前言
本篇是对于KMP单模式匹配以及AC算法多模式匹配的简单讲解,KMP算法与AC算法是关键字检索中的常见算法,能够快速而高效地查找出目标字符串中的多个关键字的匹配情况,而要检索的关键字通常被称为模式串,因此模式匹配四个字也就好理解了。网上的很多对于KMP的讲解总是结合了很多的数学公式,很多的晦涩难懂的专业词语,让人看了很头大,至少对于蠢笨的我来说,实在是一场煎熬,因此本篇的说明尽量做到通俗易懂,从逻辑以及思考方式的角度来对模式匹配的算法进行讲解。
一、KMP单模式匹配算法
1、综述
在描述多模式匹配算法之前,对于单模式匹配先进行一个简单的描述。单模式匹配与多模式匹配的不同点在于单模式匹配是搜索一个关键字,多模式匹配是搜索多个关键字。
单模式匹配解决的是在长度为m的目标串(一个长字符串L)中查找长度为n的模式串(短字符串S)的问题,如果按照最粗糙的方法暴力求解,代码应该是这样的:
for(inti=0; i<m; i++){
for(intj=0; j<n; j++){
//依次比较L[i] 与S[j],当完全相等的情况下记录
}
}
嗯,很不错的代码,思路清晰,结构明