Pagini recente » Cod sursa (job #2509179) | Cod sursa (job #3291086) | Cod sursa (job #34622) | Cod sursa (job #3038181) | Cod sursa (job #2322601)
#include <iostream>
#include <fstream>
#include <string.h>
using namespace std;
ifstream fin("prefix.in");
ofstream fout("prefix.out");
char S[1000001];
int pref[1000001],t;
int maxi;
void kmp(char S[])
{
int n=strlen(S+1);
int j=0;
for(int i=2;i<=n;i++)
{
while(j!=0 && S[j+1]!=S[i]) j=pref[j];
if(S[j+1]==S[i])
j++;
pref[i]=j;
}
}
int main()
{
int t;
fin>>t;
for(int i=1;i<=t;i++)
{
fin>>S+1;
maxi=0;
kmp(S);
int n=strlen(S+1);
for(int i=1;i<=n;i++)
{
if(pref[i])
if(i%(i-pref[i])==0)
maxi=i;
}
fout<<maxi<<"\n";
}
return 0;
}