题解 | #最长回文子串#

最长回文子串

http://www.nowcoder.com/practice/b4525d1d84934cf280439aeecc36f4af

双指针中心扩散法,回文有两种情况,以单个字符对称,或者以两个字符对称
import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param A string字符串 
     * @return int整型
     */
    public int getLongestPalindrome (String A) {
        // write code here
        char []c=A.toCharArray();
        int n=c.length;
        int max=0;
        for(int i=0;i<n;i++){
            max=Math.max(expand(c,i,i,n,1),max);
            max=Math.max(expand(c,i,i+1,n,2),max);
        }
        return max;
    }
     public int expand(char[]c,int i,int j,int n,int addLength){
        int cnt=0;
            while(i>=0&&j<n){
                if(c[i]==c[j]){
                    cnt+=2;
                }
                else{
                    break;
                   }
                i--;
                j++;
            }
        return cnt-2+addLength;
        
    }
}
全部评论

相关推荐

11-27 12:43
已编辑
门头沟学院 C++
点赞 评论 收藏
分享
11-01 20:03
已编辑
门头沟学院 算法工程师
Amazarashi66:这种也是幸存者偏差了,拿不到这个价的才是大多数
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务