给出一个字符串,你可以通过在首尾加入字符使其变成一个具有周期T(T>=2)的字符串,求所需加入的最少字符数。
所考察算法仍然是对next数组含义的理解
#include<cstdio>
#include<cstring> char S[];
int next[];
int len; void getNext()
{
int j=,k=-;
next[]=-;
while(j<len)
if(k==-||S[j]==S[k])
next[++j]=++k;
else
k=next[k];
}
void printNext()
{
for(int i=;i<len;i++)
printf("%3c",S[i]);
puts("");
for(int i=;i<=len;i++)
printf("%3d",next[i]);
puts("");
} int main()
{
int T;scanf("%d",&T);
while(T--)
{
scanf("%s",S);
len=strlen(S);
getNext();
// printNext();
int t=len-next[len]; //t即为最小周期
if(t==len)
printf("%d\n",len);
else if(len%t==)
puts("");
else
printf("%d\n",t-len%t);
}
}