Cod sursa(job #3329029)

Utilizator GILIEDAVIDGilie David Florin GILIEDAVID Data 11 decembrie 2025 16:21:10
Problema Prefix Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.61 kb
#include <iostream>
#include <fstream>
#include <cstring>
using namespace std;
ifstream f("prefix.in");
ofstream g("prefix.out");
string s;
int t,lps[1000005];
void buildPrefix(string A)
{
    int i, k=0,sol=0,n;
    n=A.size();
    for (i=2; i<=n; i++)
    {
        while (k && A[k] != A[i-1]) k = lps[k];
        if (A[k] == A[i-1]) k++;
        lps[i]=k;
        if(lps[i]>0&&i%(i-lps[i])==0)
            sol=i;
    }
    for (i=1; i<n; i++) lps[i]=0;
    g<<sol<<'\n';
}
int main()
{
    f>>t;
    for(int i=1;i<=t;i++)
    {
        f>>s;
        buildPrefix(s);
    }
    return 0;
}