思路:利用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;
}