下面的程序对next生成算法进行了优化,比前面的方法快。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int index_kmp(char S[ ], char T[ ], int next[])
{
int i, j, S_len = strlen(S), T_len = strlen(T);
i = j = 0;
while (i < S_len && j < T_len) {
if (j == -1 || S[ i ] == T[ j ]) { i++; j++;}
else { j = next[ j ]; }
}
if (j == T_len) return (i - T_len);
return -1;
}
void get_next(char T[ ], int next[])
{
int i, j, T_len = strlen(T);
i = 0; j = -1;
next[0] = -1;
while (i < T_len - 1) {
if (j == -1 || T[ i ] == T[ j ]) {
i++; j++;
if (T[ i ] == T[ j ])
next[ i ] = next[ j ];
else
next[ i ] = j;
}
else j = next[ j ];
}
}
#define MAX_SIZE 256
int main()
{
char szMain[MAX_SIZE];
char szSub[MAX_SIZE];
int i, iIndex, iSubLen, aiNext[MAX_SIZE];
printf("input main string:/n");
scanf("%255s", szMain);
printf("input sub string:/n");
scanf("%255s", szSub);
get_next(szSub, aiNext);
iSubLen = strlen(szSub);
printf("next[]: ");
for (i = 0; i < iSubLen; i++)
{
printf("%d ", aiNext[i]);
}
printf("/n");
iIndex = index_kmp(szMain, szSub, aiNext);
printf("index = %d/n", iIndex);
fgets(szMain, MAX_SIZE, stdin);
getchar();
return 0;
}
该博客展示了对next生成算法的优化程序。通过代码实现了KMP算法中的index_kmp和get_next函数,可用于字符串匹配。程序接收用户输入的主串和子串,计算next数组并输出,最后输出匹配结果的索引,优化后的算法比之前更快。
170

被折叠的 条评论
为什么被折叠?



