相关算法视频:https://www.bilibili.com/video/av3246487?from=searchseid=2407601922148792452 看完后绝对有助于理解 根据kmp算法思路: 计算next数组代码如下: void cal_next( char *str, int * next){ next[ 0 ] = - 1 ; /
相关算法视频:https://www.bilibili.com/video/av3246487?from=search&seid=2407601922148792452
看完后绝对有助于理解
根据kmp算法思路:
计算next数组代码如下:
void cal_next(char *str, int *next) { next[0] = -1;//next[0]初始化为-1,-1表示不存在相同的最大前缀和最大后缀 int k = -1;//k初始化为-1 for (int q = 1; q <= strlen(str)-1; q++) { while (k > -1 && str[k + 1] != str[q])//如果下一个不同,那么k就变成next[k],注意next[k]是小于k的,无论k取任何值。 { k = next[k];//往前回溯 } if (str[k + 1] == str[q])//如果相同,k++ { k = k + 1; } next[q] = k;//这个是把算的k的值(就是相同的最大前缀和最大后缀长)赋给next[q] } }
KMP
int KMP(char *str, char *ptr) { int next [500]; cal_next(ptr, next);//计算next数组 int k = -1; for (int i = 0; i < strlen(str); i++) { while (k >-1&& ptr[k + 1] != str[i])//ptr和str不匹配,且k>-1(表示ptr和str有部分匹配) k = next[k];//往前回溯 if (ptr[k + 1] == str[i]) k = k + 1; if (k == strlen(ptr)-1)//说明k移动到ptr的最末端 { //cout << "在位置" << i-plen+1<< endl; //k = -1;//重新初始化,寻找下一个 //i = i - plen + 1;//i定位到该位置,外层for循环i++可以继续找下一个(这里默认存在两个匹配字符串可以部分重叠),感谢评论中同学指出错误。 return i-strlen(ptr)+1;//返回相应的位置 } } return -1; }
参考博客:https://blog.csdn.net/starstar1992/article/details/54913261/