数据结构与算法之KMP算法中Next数组代码原理分析

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

一、KMP算法之Next数组代码原理分析

      1.Next数组定义

      当模式匹配串T失配的时候,Next数组对应的元素指导应该用T串的哪个元素进行下一轮的匹配。

      我们会发现,匹配串T下标为1位置的next数组的值总为0,而其他位置需要看该位置的前缀和后缀有几个匹配的字符,比如有n个匹配的字符,则next数组的值为n+1

      2.分析next数组代码实现

      如下图所示,我们通过代码来分析一下next数组的实现思路:


// 获取匹配串每个位置的next值
void get_next(String T, int *next){

    // T[0]用来存放匹配串的长度

    j = 0;
    i = 1;
    next[1] = 0; // 我们可以确定next[1] = 0

    while(i

      数据结构与算法之KMP算法中Next数组代码原理分析_第1张图片

            

            数据结构与算法之KMP算法中Next数组代码原理分析_第2张图片

            数据结构与算法之KMP算法中Next数组代码原理分析_第3张图片

             

            数据结构与算法之KMP算法中Next数组代码原理分析_第4张图片

            

 

本文为原创文章,如果对你有一点点的帮助,别忘了点赞哦!比心!如需转载,请注明出处,谢谢!

 

转载于:https://my.oschina.net/aibinxiao/blog/1853308

你可能感兴趣的:(数据结构与算法之KMP算法中Next数组代码原理分析)