Pagini recente » Cod sursa (job #2182450) | Cod sursa (job #1944146) | Cod sursa (job #2725495) | Cod sursa (job #2550692) | Cod sursa (job #1309623)
#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;
if(k&&i%(i-k)==0) l=i;
}
fprintf(fout,"%d\n",l);
}
}