Pagini recente » Cod sursa (job #2863860) | Cod sursa (job #1188978) | Cod sursa (job #3141653) | Cod sursa (job #194465) | Cod sursa (job #1301681)
#include <iostream>
#include <fstream>
#include <cstring>
using namespace std;
const int N = 1000010;
ifstream F("prefix.in");
ofstream G("prefix.out");
int t,n,pi[N];
char a[N];
int solve(char a[],int n)
{
int p = 0,ans = 0;
for (int i=2;i<=n;++i)
{
while ( p>0 && a[i] != a[p+1] )
p = pi[p];
if ( a[i] == a[p+1] )
p++;
pi[i] = p;
if ( i % (i-p) == 0 )
if ( p > 0 )
ans = i;
}
return ans;
}
int main()
{
F>>t, F.get();
while ( t-- )
{
F.getline(a+1,N);
n = strlen(a+1);
G<<solve(a,n)<<'\n';
}
}