LeetCode—最长回文子串

254 阅读1分钟

最长回文子串

给你一个字符串 s,找到 s 中最长的回文子串。

回文串”是一个正读和反读都一样的字符串,比如“level”或者“noon”等等就是回文串

示例 1:
输入:s = "babad"
输出:"bab"
解释:"aba" 同样是符合题意的答案。
示例 2:
输入:s = "cbbd"
输出:"bb"
示例 3:
输入:s = "a"
输出:"a"
示例 4:
输入:s = "ac"
输出:"a"

来源:力扣(LeetCode) 链接:leetcode-cn.com/problems/lo…

//暴力
class Solution {
    public String longestPalindrome(String s) {
        int len = s.length();
        if(len < 2) return s;
        int maxLen = 1;
        int begin = 0;
        char[] charArray = s.toCharArray();

        for(int i=0; i<len-1; i++){
            for(int j=i+1; j<len; j++){
                if(j-i+1 > maxLen && check(charArray,i,j)){
                    maxLen = j - i + 1;
                    begin = i;
                }
            }
        }
        return s.substring(begin,begin+maxLen);
    }
    public boolean check(char[] charArray,int left,int right){
        while(left < right){
            if(charArray[left] != charArray[right]) return false;
            right--;
            left++; 
       }
       return true;
    }
}
  • 中心扩散法
    • 每一个位置都要向边扩散
    • 首先从某字符往左找,如果找到与当前位置不同的则停止
    • 从某字符往右找,如果找到与当前位置不同的则停止
public String longestPalindrome1(String s) {

        if (s == null || s.length() == 0) {
            return "";
        }
        int strLen = s.length();
        int left = 0;
        int right = 0;
        int len = 1;
        int maxStart = 0;
        int maxLen = 0;

        for (int i = 0; i < strLen; i++) {
            left = i - 1;
            right = i + 1;
            while (left >= 0 && s.charAt(left) == s.charAt(i)) {
                len++;
                left--;
            }
            
            while (right < strLen && s.charAt(right) == s.charAt(i)) {
                len++;
                right++;
            }
            
            while (left >= 0 && right < strLen && s.charAt(right) == s.charAt(left)) {
                len = len + 2;
                left--;
                right++;
            }
            
            if (len > maxLen) {
                maxLen = len;
                maxStart = left;
            }
            len = 1;
        }
        return s.substring(maxStart + 1, maxStart + maxLen + 1);

    }