Pagini recente » Cod sursa (job #3312490) | Diferente pentru problema/unique intre reviziile 7 si 6 | Monitorul de evaluare | Diferente pentru problema/zigzag2 intre reviziile 31 si 17 | Cod sursa (job #3308906)
#include <fstream>
#include <string>
using namespace std;
ifstream cin("prefix.in");
ofstream cout("prefix.out");
int t, indx, p[1000005];
string s;
int main()
{
cin>>t;
while(t--){
indx=0;
cin>>s;
s='$'+s;
int n=s.size()-1;
p[1]=0;
for(int i=2; i<=n; i++){
int aux=p[i-1];
while(aux && s[aux+1]!=s[i])
aux=p[aux];
p[i]=aux;
if(s[i]==s[aux+1])
p[i]++;
int x=i-p[i];
if(x!=i && i%x==0)
indx=i;
}
cout<<indx<<'\n';
}
return 0;
}