利用c语言实现kmp算法
时间: 2023-02-26 15:00:03 浏览: 55
可以使用C语言实现KMP算法,具体步骤如下:1、创建一个模式串数组;2、将模式串中每个字符的前缀与后缀进行比较;3、比较模式串中每个字符与主串中的字符;4、如果匹配到,则继续比较;5、如果不匹配,则模式串右移,继续比较。
相关问题
C语言实现KMP算法
KMP算法的实现需要用到next数组,next数组的求解过程可以参考引用中的内容。下面是C语言实现KMP算法的代码:
```c
#include <stdio.h>
#include <string.h>
void getNext(char* pattern, int* next) {
int len = strlen(pattern);
int i = 0, j = -1;
next[0] = -1;
while (i < len) {
if (j == -1 || pattern[i] == pattern[j]) {
i++;
j++;
next[i] = j;
} else {
j = next[j];
}
}
}
int kmp(char* text, char* pattern) {
int n = strlen(text);
int m = strlen(pattern);
int i = 0, j = 0;
int* next = (int*)malloc(sizeof(int) * m);
getNext(pattern, next);
while (i < n && j < m) {
if (j == -1 || text[i] == pattern[j]) {
i++;
j++;
} else {
j = next[j];
}
}
free(next);
if (j == m) {
return i - j;
} else {
return -1;
}
}
int main() {
char text[] = "ABABDABACDABABCABAB";
char pattern[] = "ABABCABAB";
int pos = kmp(text, pattern);
if (pos == -1) {
printf("Pattern not found.\n");
} else {
printf("Pattern found at position %d.\n", pos);
}
return 0;
}
```
c语言实现KMP算法
KMP(Knuth-Morris-Pratt)算法是一种高效的字符串匹配算法,用于在一个主串中查找一个子串的出现位置。下面是C语言实现KMP算法的示例代码:
```c
#include <stdio.h>
#include <string.h>
void compute_lps(char* pattern, int* lps) {
int len = 0;
int i = 1;
int pattern_length = strlen(pattern);
lps[0] = 0;
while (i < pattern_length) {
if (pattern[i] == pattern[len]) {
len++;
lps[i] = len;
i++;
} else {
if (len != 0) {
len = lps[len - 1];
} else {
lps[i] = 0;
i++;
}
}
}
}
void kmp_search(char* pattern, char* text) {
int pattern_length = strlen(pattern);
int text_length = strlen(text);
int lps[pattern_length];
compute_lps(pattern, lps);
int i = 0;
int j = 0;
while (i < text_length) {
if (pattern[j] == text[i]) {
j++;
i++;
}
if (j == pattern_length) {
printf("Pattern found at index %d\n", i - j);
j = lps[j - 1];
} else if (i < text_length && pattern[j] != text[i]) {
if (j != 0) {
j = lps[j - 1];
} else {
i++;
}
}
}
}
int main() {
char text[] = "ABABDABACDABABCABAB";
char pattern[] = "ABABCABAB";
kmp_search(pattern, text);
return 0;
}
```
这段代码中,compute_lps() 函数用于计算模式串的最长公共前后缀长度数组 lps[],kmp_search() 函数用于在文本串中搜索模式串。