正如提示所说,最大长度是n/3,所以直接从大到小枚举即可;
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=1e6+10;
int Next[maxn];
void getnext(char* t)
{
int i,len=strlen(t);
Next[0]=len;
for(i=0;i<len-1&&t[i]==t[i+1];i++);
Next[1]=i;
int a=1;
for(int k=2;k<len;k++){
int p=a+Next[a]-1,l=Next[k-a];
if(k+l-1>=p){ //l>=p-k+1
int j=max(p-k+1,0);
while(k+j<len&&t[k+j]==t[j]) j++;
Next[k]=j;a=k;
}else Next[k]=l;
}
}
int main()
{
char s[maxn];
while(scanf("%s",s)!=EOF){
getnext(s);
int len=strlen(s);
int flag=0;
for(int i=len/3;i>=0;i--){
if(Next[len-i]<i) continue;
for(int j=i;j<len-2*i;j++){
if(Next[j]>=i&&j+i-1<len-Next[len-i]){
flag=i;
break;
}
}
if(flag) break;
}
printf("%d\n",flag);
}
return 0;
}