下面是模式值使用第二种表示方法的匹配函数(next[0]=0)
int my_KMP(char *S, char *T, int pos)
{
int i = pos, j = 0;//pos(S 的下标0≤pos<StrLength(S))
while ( S[i] != '\0' && T[j] != '\0' )
{
if (S[i] == T[j] )
{
++i;
++j; // 继续比较后继字符
}
else // a b a b c a a b c
// 0 0 0 1 2 0 1 1 2
{ //-1 0 -1 0 2 -1 1 0 2
i++;
j = next[j]; /*当出现S[i] !=T[j]时,
下一次的比较应该在S[i]和T[next[j]] 之间进行。要求next[0]=0。
在这两个简单示范函数间使用全局数组next[]传值。*/
}
}//while
if ( T[j] == '\0' )
return (i-j); // 匹配成功
else
return -1;
} // my_KMP
六.后话--KMP的历史
[这段话是抄的]
Cook于1970年证明的一个理论得到,任何一个可以使用被称为下推自动机的计算机抽象模型来解决的问题,也可以使用一个实际的计算机(更精确的说,使用一个随机存取机)在与问题规模对应的时间内解决。特别地,这个理论暗示存在着一个算法可以在大约m+n的时间内解决模式匹配问题,这里m和n分别是存储文本和模式串数组的最大索引。Knuth 和Pratt努力地重建了 Cook的证明,由此创建了这个模式匹配算法。大概是同一时间,Morris在考虑设计一个文本编辑器的实际问题的过程中创建了差不多是同样的算法。这里可以看到并不是所有的算法都是“灵光一现”中被发现的,而理论化的计算机科学确实在一些时候会应用到实际的应用中。
分享到:
相关推荐
### KMP字符串模式匹配详解 #### 一、引言 KMP算法,全称为Knuth-Morris-Pratt算法,是一种高效的字符串模式匹配算法。它主要用于在一个文本串中寻找一个模式串的位置,相比于传统的暴力匹配算法,KMP算法能够显著...
KMP 字符串模式匹配详解及程序 KMP 字符串模式匹配是数据结构中的经典算法,用于在一个字符串中定位另一个串。简单匹配算法的时间复杂度为 O(m*n),而 KMP 匹配算法可以证明其时间复杂度为 O(m+n)。 简单匹配算法...
### KMP字符串模式匹配详解 #### 一、引言 KMP算法,全称为Knuth-Morris-Pratt算法,是一种高效的字符串模式匹配算法。它由Donald Knuth、James H. Morris以及Vaughan Pratt三位计算机科学家共同提出,旨在解决在...
KMP字符串模式匹配通俗点说就是一种在一个字符串中定位另一个串的高效算法。简单匹配算法的时间复杂度为O(m*n);KMP匹配算法。可以证明它的时间复杂度为O(m+n).。先来看一个简单匹配算法的函数:此算法的思想是...
《KMP字符串模式匹配详解》 KMP字符串模式匹配是一种高效地在文本串(主串)中寻找目标串(模式串)出现位置的算法。相较于简单的暴力匹配算法,KMP算法显著提高了匹配效率,时间复杂度从O(m*n)优化到了O(m+n),...
**KMP字符串模式匹配算法详解** KMP(Knuth-Morris-Pratt)算法是一种高效地在主串(text)中查找子串(pattern)的字符串模式匹配算法,由Dijkstra、Morris和Pratt在1970年提出。这个算法避免了不必要的字符比较,...
### KMP字符串匹配算法 #### 一、简介 KMP(Knuth-Morris-Pratt)算法是一种高效的字符串搜索算法,由Donald Knuth、James H. Morris和Vaughan Pratt三位计算机科学家共同提出。该算法的主要优点在于它能够有效地...
**KMP字符串匹配算法详解** KMP(Knuth-Morris-Pratt)字符串匹配算法是由D.E. Knuth、V.J. Morris和J.H. Pratt三位学者于1977年提出的,它是一种高效的字符串搜索算法,主要用于在一个主串(text)中查找是否存在...
### 字符串模式匹配KMP算法详解 #### 一、引言 在计算机科学领域,字符串模式匹配是一项基本且重要的任务。它涉及到在一个较大的文本字符串(通常称为“主串”或“目标串”)中寻找一个较小的字符串(称为“模式串...
**字符串模式匹配BF算法详解** 在信息技术领域,字符串模式匹配是一项基本且重要的任务,它用于在文本中查找是否存在特定的子串。BF算法,全称为Brute Force(暴力)算法,是最直观的一种字符串模式匹配算法。它...
本文将介绍一种名为KMP的字符串匹配算法。KMP算法(Knuth-Morris-Pratt算法)是一种高效的字符串匹配算法,由Donald Knuth、Vaughan Pratt和James H. Morris共同发明。KMP算法通过使用一个称为“部分匹配表”或...
KMP(Knuth-Morris-Pratt)算法作为一种高效的字符串匹配算法,通过预处理模式串构建一个辅助数组来避免不必要的回溯,从而显著提高了匹配效率。 #### KMP算法原理 KMP算法的核心在于构建一个**next数组**,用于...
本文将介绍一种名为KMP的字符串匹配算法。KMP算法(Knuth-Morris-Pratt算法)是一种高效的字符串匹配算法,由Donald Knuth、Vaughan Pratt和James H. Morris共同发明。KMP算法通过使用一个称为“部分匹配表”或...
KMP算法是一种高效的字符串模式匹配算法,它通过预处理模式字符串来避免重复比较,从而大大提高了搜索效率。 ##### 3.1 KMP算法原理 KMP算法的核心在于构建一个称为“部分匹配表”(Next数组)的数据结构,该表...