理解“KMP”算法,转换成程序并用C语言实现
时间: 2023-06-19 10:08:17 浏览: 92
KMP算法 C语言实现
4星 · 用户满意度95%
KMP算法是一种字符串匹配算法,用于在一个文本串S内查找一个模式串P的出现位置。它的主要思想是,当字符串匹配失败时,尽量利用已经匹配成功的信息,使模式串向右移动尽可能少的位数,从而提高匹配效率。
以下是KMP算法的C语言实现:
```c
#include <stdio.h>
#include <string.h>
void getNext(char* p, int* next) {
int n = strlen(p);
int j = 0, k = -1;
next[0] = -1;
while (j < n - 1) {
if (k == -1 || p[j] == p[k]) {
j++;
k++;
next[j] = k;
} else {
k = next[k];
}
}
}
int kmp(char* s, char* p) {
int n = strlen(s);
int m = strlen(p);
int i = 0, j = 0;
int next[m];
getNext(p, next);
while (i < n && j < m) {
if (j == -1 || s[i] == p[j]) {
i++;
j++;
} else {
j = next[j];
}
}
if (j == m) {
return i - j;
} else {
return -1;
}
}
int main() {
char s[] = "ABABABABCABAAB";
char p[] = "ABABCABAA";
int pos = kmp(s, p);
if (pos == -1) {
printf("Pattern not found.\n");
} else {
printf("Pattern found at position %d.\n", pos);
}
return 0;
}
```
在上面的代码中,函数getNext用于计算模式串的next数组,函数kmp用于在文本串中查找模式串,并返回模式串在文本串中的位置。在main函数中,我们定义了一个文本串s和一个模式串p,并调用kmp函数进行匹配。如果匹配成功,就输出模式串在文本串中的位置,否则输出“Pattern not found.”。
阅读全文