Pagini recente » Cod sursa (job #2982707) | Cod sursa (job #2204542) | Cod sursa (job #3144267) | Cod sursa (job #728451) | Cod sursa (job #2559267)
#include<fstream>
#include<string.h>
using namespace std;
ifstream in("prefix.in");
ofstream out("prefix.out");
char s[1000001];
int pi[1000001];
int main()
{
int n,i,now,t,j,x;
in>>t;
for(j=1;j<=t;j++)
{
in>>s+1;
x=0;
n=strlen(s+1);
for(i=2;i<=n;i++)
{
now=pi[i-1];
while(now>0&&s[now+1]!=s[i])
now=pi[now];
if(s[now+1]==s[i])
now++;
pi[i]=now;
if(pi[i]!=0&&i%(i-pi[i])==0)
x=i;
}
out<<x<<'\n';
}
return 0;
}