Cod sursa(job #2560371)

Utilizator lucaperjuLuca Perju Verzotti lucaperju Data 27 februarie 2020 22:10:43
Problema Prefix Scor 80
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.75 kb
#include <fstream>
#include <cstring>
using namespace std;
ifstream cin ("prefix.in");
ofstream cout ("prefix.out");
const int mod=101267;
char v[1000006];
int lps[1000006];
int main()
{
   /* ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);*/
    long long l,t,i,j,a,b,c,ra,rb,rc,n,d;
    cin>>t;
    while(t--)
    {
        cin>>(v+1);
        n=strlen(v+1);
        int rz=0;
        for(i=2;i<=n;++i)
        {
            int 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/2 && i%(i-lps[i])==0)
                rz=i;
        }
        cout<<rz<<'\n';
    }
    return 0;
}