Pagini recente » Arhiva de probleme | Cod sursa (job #1171649) | Cod sursa (job #2566089) | Cod sursa (job #322476) | Cod sursa (job #3182061)
#include <iostream>
#include <fstream>
#include <cstring>
using namespace std;
ifstream f("prefix.in");
ofstream g("prefix.out");
int n,j,nr,v[1000005],i,t;
char s[1000005];
int main()
{f>>nr;
for(t=1;t<=nr;t++)
{f>>s;
for(i=1,j=0;s[i];++i)
{if(s[i]==s[j]) v[i]=++j;
else {if(s[i]==s[0])
v[i]=j;
else v[i]=0;}
}
for(;i;--i)
if(v[i-1]&&i%(i-v[i-1])==0)
break;
g<<i<<'\n';
}
return 0;
}