Pagini recente » Cod sursa (job #2659537) | Cod sursa (job #1045957) | Cod sursa (job #1467463) | Cod sursa (job #3148791) | Cod sursa (job #2554589)
#include <fstream>
#include <cstring>
using namespace std;
ifstream cin ("prefix.in");
ofstream cout ("prefix.out");
char s[1000005];
int pi[1000005];
int main()
{
int t,x,n,now,i;
cin>>t;
while (t)
{
cin>>s+1;
x=0;
n=strlen(s+1);
for (i=2;i<=n;i++)
{
now=pi[i-1];
while (now and s[now+1]!=s[i])
now=pi[now];;
if (s[now+1]==s[i])
now++;
pi[i]=now;
if (pi[i] and i%(i-pi[i])==0)
x=i;
}
cout<<x<<'\n';
t--;
}
return 0;
}