leetcode 5 Longest Palindromic Substring Java & JavaScript解法

題目詳情

Given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.

題目的意思是輸入一個字符串,咱們要找到這個字符串的最長的知足迴文條件的子字符串。
迴文的意思就是反轉字符串後和原字符串相等。java

Example:
Input: "babad"
Output: "bab"
Note: "aba" is also a valid answer.
Example:
Input: "cbbd"
Output: "bb"code

想法

  • 這道題一個比較好的想法是以遍歷到的每一個元素爲起始點,向兩邊擴展,直到找到知足以這個元素爲中心的最長迴文字符串。
  • 由於這種想法沒次都是兩邊同時擴展。因此要分目標字符串長度爲奇數、目標字符串爲偶數兩種狀況。進行兩次擴展。

Java解法

private int maxLen,low;
    
    public String longestPalindrome(String s){
        int length = s.length();
        if(length < 2)return s;
        
        for(int i=0;i<length-1;i++){
            extendPalindorme(s,i,i);
            extendPalindorme(s,i,i+1);
        }
        return s.substring(low,low+maxLen);
    }
    
    public void extendPalindorme(String s,int begin,int end){
        while(begin >= 0 && end < s.length() && (s.charAt(begin)== s.charAt(end))){
            begin --;
            end ++;
        }
        if(maxLen < end-begin-1){
            low = begin+1;
            maxLen = end-begin-1;
        }
    }

javaScript解法

  • 這裏面我用的是全局變量。沒次還要從新賦值,感受有點蠢=..=
/**
 * @param {string} s
 * @return {string}
 */
var maxLen = 0;
var low = 0; 
var longestPalindrome = function(s) {
    var length = s.length;
    if(length < 2){
        return s;
    }

    for(var i=0;i<length-1;i++){
        extendPalindrome(s,i,i);
        extendPalindrome(s,i,i+1);

    }
    let res = s.substring(low,low+maxLen);
    low =0;maxLen= 0;
    return res;


};
function  extendPalindrome(s,start,end){

    while(start >= 0 && end < s.length && (s[start] == s[end])){
        start --;
        end ++;

    }
    if(maxLen < end-start - 1){
        low = start + 1;
        maxLen = end-start-1;
    }
}
相關文章
相關標籤/搜索