Pagini recente » Cod sursa (job #2099464) | Cod sursa (job #113094) | Cod sursa (job #896507) | Cod sursa (job #394584) | Cod sursa (job #1309625)
#include <cstdio>
#include <cstring>
const unsigned MAXN=1000000;
unsigned prefix[MAXN+1];
char s[MAXN+2];
int main(){
FILE *fin=fopen("prefix.in","r");
FILE *fout=fopen("prefix.out","w");
int T; fscanf(fin,"%d",&T);
while(T--){
fscanf(fin,"%s",s+1);
unsigned n=strlen(s+1);
unsigned l=0;
prefix[1]=0;
unsigned k=0;
for(unsigned i=2;i<=n;++i){
while(k>0&&s[i]!=s[k+1]) k=prefix[k];
if(s[k+1]==s[i]) k++;
prefix[i]=k;
}
for(unsigned i=n;i>0;--i) if(prefix[i]&&i%(i-prefix[i])==0) {l=i;break;}
fprintf(fout,"%d\n",l);
}
}