Pagini recente » Istoria paginii runda/arnold-testare-2 | Cod sursa (job #1596479) | Cod sursa (job #1604429) | Cod sursa (job #3162912) | Cod sursa (job #2288914)
#include <iostream>
#include <fstream>
#include <cstring>
using namespace std;
ifstream f("prefix.in");
ofstream g("prefix.out");
char s[1000005];
int urm[1000005],m;
void prefix()
{
int i,k=0;
urm[1]=0;
for(i=2; i<=m; i++)
{
while(k>0&&s[k]!=s[i-1])
k=urm[k];
if(s[k]==s[i-1])k++;
urm[i]=k;
}
}
void kmp()
{
int i,k=0;
for(i=m; i>=1; i--)
{
if(urm[i]!=0&&(i%(i-urm[i])==0))
{
g<<i<<'\n';
break;
}
if(i==1) g<<0<<'\n';
}
}
int main()
{
int n,i;
f>>n;
for(i=1; i<=n; i++)
{
f>>s;
m=strlen(s);
prefix();
kmp();
}
return 0;
}