按照递推的思想求解next[]数组

按照递推的思想求解next[]数组

根据定义next[0]=-1,假设next[j]=k, 即P[0...k-1]==P[j-k,j-1]

  1. 若P[j]P[k],则有P[0..k]P[j-k,j],很显然,next[j+1]=next[j]+1=k+1;

  2. 若P[j]!=P[k],则可以把其看做模式匹配的问题,即匹配失败的时候,k值如何移动,显然k=next[k]。

因此可以这样去实现:

void getNext(char *p,int *next)
{
    int j,k;
    next[0]=-1;
    j=0;
    k=-1;
    while(j<strlen(p)-1)
    {
        if(k==-1||p[j]==p[k])    //匹配的情况下,p[j]==p[k]
        {
            j++;
            k++;
            next[j]=k;
        }
        else                   //p[j]!=p[k]
            k=next[k];
    }
}

KMP算法-博客园-海子

posted @ 2018-05-14 19:56  静世孔明  阅读(194)  评论(0编辑  收藏  举报