【题目】
【思路】
直接运用Manacher算法。
【代码】
#include <stdio.h>
#include <string.h>
#define maxSize 1000005
#define min(x,y) (x<y)? x:y
char str[maxSize], s[maxSize*2+3];
long int r[maxSize*2+3];
long int manacher()
{
long int i,len=strlen(str);
s[0]='$'; s[len*2+1]='#'; s[len*2+2]='*';
for (i=0;i<len;i++) {s[2*i+1]='#'; s[2*i+2]=str[i];}
long int j=1; r[1]=1;
for (i=2;i<=len*2;i++)
{
if (r[j]+j>i) r[i]=min(r[j]+j-i, r[2*j-i]); else r[i]=1;
while (s[i-r[i]]==s[i+r[i]]) r[i]++;
if (i+r[i]>j+r[j]) j=i;
}
long int ans=0;
for (i=1;i<=len*2;i++) if (r[i]>ans) ans=r[i];
return ans-1;
}
int main()
{
int i;
for (i=1;;i++)
{
scanf("%s",str);
if (strcmp(str,"END")==0) break;
printf("Case %d: %d\n",i,manacher());
}
return 0;
}