class Solution {
public:
    int getLongestPalindrome(string A, int n) {
        // write code here
        if(n < 2)return A.size();
        //处理特殊情况
        int max = 0;
        for(int i = 0; i < n;){
            if(n-i <= max / 2) break;//剩余数量不足最大值的一半时,直接终止
            int l = i;
            int r = i;
            while(r < n-1 && A[r+1] == A[r]) r++;//去除重复的中心字符,如bbb
            i = r + 1;
            while(r < n- 1 && l > 0 && A[r+1] == A[l-1]){
                r++;
                l--;
            }
            max = (r-l+1)>max?r-l+1:max;
        }
        return max;
    }
};