kmp算法求next数组c语言
时间: 2023-10-16 16:27:15 浏览: 157
KMP算法是一种字符串匹配算法,用于在一个字符串中查找另一个字符串的出现位置。它的核心是求出模式串的next数组。下面是KMP算法求next数组的C语言代码实现:
```c
void getNext(char* p, int* next) {
int len = strlen(p);
next[0] = -1;
int k = -1;
int j = 0;
while (j < len - 1) {
if (k == -1 || p[k] == p[j]) {
++k;
++j;
next[j] = k;
} else {
k = next[k];
}
}
}
```
其中,p是模式串,next是next数组。这段代码中,我们首先将next[0]设置为-1。然后,我们通过循环计算next数组中的每个元素。在循环中,我们用k表示最长相等前后缀的长度,j表示后缀的索引。如果k==-1或者p[k]等于p[j],我们将k和j都加1,并且将next[j]设置为k。否则,我们将k设置为next[k](即p[0]~p[k-1]的最长相等前后缀的长度),继续循环。最后,我们得到了完整的next数组。
需要注意的是,这里的next数组的意义与其他地方可能不同,有些地方可能会将next[0]设置为0。这里我们将其设置为-1,是因为在KMP算法中,当next[j]==-1时,表示p[0]~p[j]中不存在任何一个前缀同时也是后缀。
阅读全文