Pagini recente » Cod sursa (job #2428262) | Cod sursa (job #943456) | Cod sursa (job #811769) | Cod sursa (job #834504) | Cod sursa (job #2261954)
#include <cstdio>
#include <cstring>
#include <cctype>
using namespace std;
char v[1000002];
int pee[1000002];
int main()
{
int t,i,n,k,rez;
freopen("prefix.in","r",stdin);
freopen("prefix.out","w",stdout);
scanf("%d\n",&t);
while(t--)
{
scanf("%s\n",v+1);
for(n=1; isalpha(v[n]); n++);
n--;
for(i=1; i<=n; i++)
pee[i]=0;
k=0;
rez=0;
for(i=2; i<=n; i++)
{
while(k && v[k+1]!=v[i])
k=pee[k];
if(v[k+1]==v[i])
++k;
if(i%(i-k)==0 && k)
rez=i;
pee[i]=k;
}
printf("%d\n",rez);
}
return 0;
}