字符串匹配算法:KMP(The Knuth-Morris-Pratt Algorithm)

Posted iOS逆向

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了字符串匹配算法:KMP(The Knuth-Morris-Pratt Algorithm)相关的知识,希望对你有一定的参考价值。

文章目录

前言

字符串匹配是计算机的基本任务之一。

KMP算法的思想是,设法利用已知的匹配信息,不要把"搜索位置"移回已经比较过的位置,继续把它向后移,这样就提高了效率。

做法:针对搜索词,算出一张《部分匹配表》(Partial Match Table)。

已知空格与D不匹配时,前面六个字符"ABCDAB"是匹配的。查表可知,最后一个匹配字符B对应的"部分匹配值"为2,因此按照下面的公式算出向后移动的位数:

移动位数 = 已匹配的字符数 - 对应的部分匹配值

以上是关于字符串匹配算法:KMP(The Knuth-Morris-Pratt Algorithm)的主要内容,如果未能解决你的问题,请参考以下文章

POJ-2752 Seek the Name, Seek the Fame 字符串问题 KMP算法 求前后缀串相同数木

KMP算法学习记录----Jake Boxer博文学习部分

kmp匹配

kmp算法详解

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

字符串匹配---KMP算法