Pagini recente » Cod sursa (job #244181) | Cod sursa (job #1838179) | Cod sursa (job #1017638) | Cod sursa (job #879327) | Cod sursa (job #1113716)
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
char s[1000005];
int p[1000005],n,i,j,k,m,t;
int main()
{
freopen("prefix.in","r",stdin);
freopen("prefix.out","w",stdout);
scanf("%d\n",&n);
for (j=1;j<=n;j++)
{
gets(s+1);
m=strlen(s+1);
t=k=p[k]=0;
for (i=2;i<=m;i++)
{
while (k && s[k+1]!=s[i]) k=p[k];
if (s[k+1]==s[i]) k++;
p[i]=k;
if (p[i] && i-p[i]!=0 && i%(i-p[i])==0) t=i;
}
printf("%d\n",t);
}
return 0;
}