hdu 3336 KMP走起 如果让我说:我只能说,实力决定一切

来源:互联网 发布:淘宝最好的手机店 编辑:程序博客网 时间:2024/04/30 13:14

思路:利用KMP求解串的前缀的个数:

例如:          a                   b                     a                    b      

next:        -1                  0                    0                     1      

含义:当前字符前面与开头匹配串的最大长度

所以:每当next[i]>0时,肯定前面有一个匹配。

注意:别忘了该字符串的长度为4(但是下标为0),查找时for()应该等于该长度,因为abab中 ab符合条件。

#include<iostream>#include<algorithm>#include<cstdio>#include<string.h>using namespace std;int next[200100];void get_next(string a){    int k=-1;    int j=0;    next[0]=-1;    while(j<a.size())    {        if(k==-1||a[k]==a[j])        {            k++;            j++;            next[j]=k;        }        else            k=next[k];    }}int main(){    int T,t,i,j;    int sum=0,tem;;    string te;    scanf("%d",&T);    while(T--)    {        scanf("%d",&t);        cin>>te;        get_next(te);        for(int i=0;i<=t;i++)         printf("%d\t",next[i]);        sum=t;        for(i=1; i<=t; i++)        {            for(j=next[i]; j!=0; j=next[j]) //当前的和开头子串比较            {                printf("j=%d\n",j);                  sum++;            }            sum%=10007;        }        printf("%d\n",sum);    }    return 0;}


 

 

原创粉丝点击