美文网首页
KMP算法理解与实现

KMP算法理解与实现

作者: 一袋歌手 | 来源:发表于2018-04-04 18:12 被阅读0次

KMP算法——字符串匹配算法    

        Ep:如果给定两个字符串,规定(搜索的文章)是搜索串,(关键字)是模板串,例子如下:

在c中寻找是否寻在a,如果存在,返回开始的位置

        一般来说,我们会想到的方法就是,c中一个字符串一个字符串比较,如果一样就比较下一个,这样的方法称为暴力破解,假设搜索串长度为M,模板串长度为N,则复杂度为O(M*N)。

KMP算法的核心同类文章

        https://kb.cnblogs.com/page/176818/

        https://blog.csdn.net/starstar1992/article/details/54913261

定义一个Next【】数组,长度为模板串长度,分别表示当前字符串引入前N个元素。

数组内存放当字符串引入前N个元素的时候,前缀串和后缀串的相同个数。

next【】数组内存储最长前后缀长度,假定初始值next【0】= -1  模板串a的next【7】分别为【-1,-1,0,1,2,-1,-1】

举个例子,当next为4的时候next【4】=2,此时的字符串是ababa,前缀后缀相同的部分为aba,三个元素,由于初始为-1,所以最终结果为2【使用-1是因为这样定义比如当匹配k的时候不满足可以直接令k=next【k】,刚好是相同前缀结束的地方。

kmp算法和next原理大致相同。核心是用模板串去匹配字符串,外部循环是每次搜索字符串指针q向后移动1,循环内部如果模板串的第一个字符k和搜索串的某一个时刻所指字符串相同,模板串k+1,搜索串q+1;如果不同,模板串回退到相同前缀结束的地方,代码表现为k=next【k】,如果已经回退到最开始的地方即k=-1,相当于一切重头开始。如果某个时刻k的值等于模板串长度-1(因为k初值为-1,每次匹配成功一个字符就+1,最多可以变成len-1),则证明完全匹配成功,返回当前所指向的值。

求next代码如下

kmp算法如下

Main函数

相关文章

  • 对KMP算法的一些理解

    最近学到KMP算法,下面讲讲对KMP算法的一些个人理解,希望对大家有帮助! 对于KMP算法的理解: 整个KMP算法...

  • KMP算法 理解与实现

    KMP算法,背景不必多说,主要想写一写自己对KMP算法的一些理解和其具体实现。关于KMP算法的原理,阮一峰老师的这...

  • KMP算法

    参考文献1.B站灯笼哥2.KMP算法python实现3.如何更好的理解和掌握 KMP 算法?

  • KMP算法理解与实现

    KMP算法——字符串匹配算法 Ep:如果给定两个字符串,规定(搜索的文章)是搜索串,(关键字)是模板串,例...

  • KMP算法学习札记

    参考文章 知乎:如何更好的理解和掌握 KMP 算法?从头到尾彻底理解KMPKMP 算法(1):如何理解 KMP(原...

  • 字符串匹配与KMP算法

    1.朴素字符串匹配算法 2.KMP算法 求前缀函数 实现KMP算法 3.测试代码

  • KMP算法文章合集

    字符串的查找:朴素查找算法和KMP算法 暴力匹配算法与KMP算法(串的匹配) 字符串查找算法BF和KMP 字符串匹...

  • 算法(2)KMP算法

    1.0 问题描述 实现KMP算法查找字符串。 2.0 问题分析 “KMP算法”是对字符串查找“简单算法”的优化。 ...

  • 深入理解KMP算法

    深入理解KMP算法 时间:20180313 KMP算法的核心是 求公共最大前后缀。 画图分析 继续分析如何利用前后...

  • 数据结构与算法14-字符串匹配与KMP

    什么是KMP KMP算法是在字符串匹配算法中比较绕的.主要是需要理解KMP中next数组求解的必要性以及j 的回溯...

网友评论

      本文标题:KMP算法理解与实现

      本文链接:https://www.haomeiwen.com/subject/whzqixtx.html