import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNext()) {
            String s = in.next();
            System.out.println(LRS(s));
        }
    }

    public static int LRS(String s) {
        char[] chars = s.toCharArray();
        int len = chars.length;
        //dp[i][j]表示s[i...j]中最长回文串的长度,最长就是length
        int[][] dp = new int[len][len];
        //初始化
        for(int i=0;i<len;i++){
            dp[i][i]=1;//每个字符本身就是一个长度为1的回文串
        }
        //转移方程
        //注意:最外层循环条件:枚举子串的长度
        for(int l=2;l<=len;l++){
            //内层循环条件为左边界
            for(int i=0;i<len;i++){
                //计算右边界
                int j=i+l-1;
                if(j>=len)break;
                if(chars[i]==chars[j]){
                    dp[i][j]=dp[i+1][j-1]+2;
                }else{
                    dp[i][j]=Math.max(dp[i+1][j],dp[i][j-1]);
                }
            }
        }
        return dp[0][len-1];
    }
}