。。。

导航

hdu 3336 Count the string【kmp】

http://acm.hdu.edu.cn/showproblem.php?pid=3336

题意:给你一个字符串,问字符串每一个前缀在字符串中的出现总次数。

思路:kmp的应用,自身和自身进行匹配,每次匹配时,如果没有匹配到结束,模式串按next数组向后移动,出现匹配至结束的情况,匹配串往后移动一位

  ,匹配过程中,出现失配时,统计当前已经匹配的字符个数,累加到总数中,直到匹配串移动到最后一位。

其实前两天就在网上看题解用kmp+dp的方法来写了这道题,然而后来细思一些细节,自己并没有弄懂,所以,我就没有写成题解,最后,还是我师父出面,把这道题给解释了

#include<stdio.h>
#define N 200010
#define mod 10007
int next[N];
char str[N];
void Get_next(int n)
{
    int j ,k;
    j = 0;
    next[j] = k = -1;
    while(j <= n)
    {
        if(k == -1||str[j] ==str[k])
            next[++j] = ++k;
        else
            k = next[k];
    }
    return;
}

int KMP(int n)
{
    int i,j,k;
    i = 1;
    j = k = 0;
    while(i <= n)
    {
        if(j == -1||str[i]==str[j])
        {
            i++;
            j++;
        }
        else//失配时 
        {
            k += j;//每次累加起点不同匹配的字符串长度,保证了起点不重复 
            k%=mod;
            j = next[j];
        }
    }
    return k ;
}
int main()
{
    int t,n;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d",&n);
        getchar();
        scanf("%s",str);
        Get_next(n);
        printf("%d\n",(KMP(n)+n)%mod);
    }
    return 0;
}

 

posted on 2017-11-07 19:27  大学僧  阅读(156)  评论(0编辑  收藏  举报