Cod sursa(job #2307299)

Utilizator usureluflorianUsurelu Florian-Robert usureluflorian Data 24 decembrie 2018 11:30:40
Problema Prefix Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.62 kb
#include <bits/stdc++.h>
using namespace std;
ifstream f ("prefix.in");
ofstream g ("prefix.out");
const int nmax=1e6+3;
int ant[nmax],k,n,t,sol;
char s[nmax];
int main()
{
    f>>t;
    while(t--)
    {
        f>>(s+1);
        n=strlen(s+1);
        k=0;
        for(int i=2;i<=n;++i)
        {
            while(k&&s[i]!=s[k+1]) k=ant[k];
            if(s[i]==s[k+1]) ++k;
            ant[i]=k;
        }
        sol=0;
        for(int i=n;i>=1;--i)
        {
            sol=max(sol,i*((i%(i-ant[i]))==0)*(ant[i]!=0));
            if(sol) break;
        }
        g<<sol<<'\n';
    }
    return 0;
}