Pagini recente » Cod sursa (job #1970446) | Cod sursa (job #1375177) | Cod sursa (job #1142404) | Cod sursa (job #1603603) | Cod sursa (job #2560371)
#include <fstream>
#include <cstring>
using namespace std;
ifstream cin ("prefix.in");
ofstream cout ("prefix.out");
const int mod=101267;
char v[1000006];
int lps[1000006];
int main()
{
/* ios_base::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);*/
long long l,t,i,j,a,b,c,ra,rb,rc,n,d;
cin>>t;
while(t--)
{
cin>>(v+1);
n=strlen(v+1);
int rz=0;
for(i=2;i<=n;++i)
{
int cur=lps[i-1];
while(cur && v[cur+1]!=v[i])
cur=lps[cur];
if(v[cur+1]==v[i])
++cur;
lps[i]=cur;
if(lps[i]>=i/2 && i%(i-lps[i])==0)
rz=i;
}
cout<<rz<<'\n';
}
return 0;
}