KMP的next数组

tzw513 2017-08-01 02:17:55
KMP的求next数组代码
void Get_next(int *next, char *str)
{
int i,j;
i = 0;
next[0] = j = -1;

int len = strlen(str);
while(i < len){
if(j==-1 || str[i]==str[j]){
next[i+1] = j+1;
i++; j++;
}
else j = next[j];
}
}
其中j=next[j]为什么这样就能令j返回-1啊????
...全文
179 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
上山老人 2017-08-02
  • 打赏
  • 举报
回复
核心思想是:为了提高匹配效率,不会一次只移动一位(全匹配),而是根据字串自身的一些特点移动多位。
上山老人 2017-08-02
  • 打赏
  • 举报
回复
你自己准备两个小一点字符串,按照kmp算法的逻辑去人工匹配一下
verphan 2017-08-01
  • 打赏
  • 举报
回复
楼主可以参考这个理解 KMP算法详解 j=next[j] 进入上面这句的时候是因为next的下一个符号不能满足条件,不能用前一个next算下一个,所以要在已匹配的字符串里面再找子串——相当于前后两个匹配子串再在内部找子串,就像A=B,然后A段的前部C与后部D满足C=D。而B段的前部后部也是C和D,所以A段的前段就等于B段的后段啦,继续匹配。
赵4老师 2017-08-01
  • 打赏
  • 举报
回复
代码功能归根结底不是别人帮自己看或讲解或注释出来的;而是被自己静下心来花足够长的时间和精力亲自动手单步或设断点或对执行到某步获得的中间结果显示或写到日志文件中一步一步分析出来的。 提醒:再牛×的老师也无法代替学生自己领悟和上厕所! 单步调试和设断点调试(VS IDE中编译连接通过以后,按F10或F11键单步执行,按Shift+F11退出当前函数;在某行按F9设断点后按F5执行停在该断点处。)是程序员必须掌握的技能之一。 百度搜相关关键字。

64,651

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧