//求最长回文子串,其中p数组存以该位为中心的最长回文串长度。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 1000005;
char str[maxn];
char initstr[maxn];
int p[maxn];
int init()
{
initstr[0] = '$';
int num = 1;
int len = strlen(str);
for(int i=0; i<len; i++)
{
initstr[num++] = '#';
initstr[num++] = str[i];
}
initstr[num++] = '#';
initstr[num] = '\0';
return num;
}
int manacher(int n)
{
int Max = 0;
int id;
int maxnum = -1;
for(int i=0; i<n; i++)
{
if(Max > i)
p[i] = min(p[2*id-i],Max-i);
else p[i] = 1;
while(initstr[i-p[i]] == initstr[i+p[i]]) p[i]++;
if(Max < i+p[i])
{
Max = i+p[i];
id = i;
}
maxnum = max(p[i], maxnum);
}
return maxnum;
}
int main()
{
while(scanf("%s",str)!=EOF)
{
int n = init();
printf("%d\n",manacher(n)-1);
}
return 0;
}