Cod sursa(job #2560384)

Utilizator lucaperjuLuca Perju Verzotti lucaperju Data 27 februarie 2020 22:16:47
Problema Prefix Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.71 kb
#include <fstream>
#include <cstring>
using namespace std;
ifstream cin ("prefix.in");
ofstream cout ("prefix.out");
char v[1000006];
int lps[1000006];
int main()
{
   /* ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);*/
    int t,i,n,rz,cur;
    cin>>t;
    while(t--)
    {
        cin>>(v+1);
        n=strlen(v+1);
        rz=0;
        for(i=2;i<=n;++i)
        {
            cur=lps[i-1];
            while(cur && v[cur+1]!=v[i])
                cur=lps[cur];
            if(v[cur+1]==v[i])
                ++cur;
            lps[i]=cur;
            if(lps[i]>=(i>>1) && i%(i-lps[i])==0)
                rz=i;
        }
        cout<<rz<<'\n';
    }
    return 0;
}