給定一個字符串 s,找到 s 中最長的迴文子串。你能夠假設 s 的最大長度爲 1000。算法
示例 1:code
輸入: "babad"
輸出: "bab"
注意: "aba" 也是一個有效答案。字符串
示例 2:io
輸入: "cbbd"
輸出: "bb"function
用的Manacher算法while
var longestPalindrome = function(s) { if (s.length == 0) return "" var str="$" var j = 1,mx = 0,id = 0, len = []; var max=0, index; for(var i = 0, l = s.length; i < l; i++) { str += "#"; str += s[i] } str += "#" for (var i = 1, l = str.length; i < l; i++) { if(i < mx) { len[i] = Math.min(len[2*id - i], mx - i) } else { len[i] = 1; } while(str[len[i] + i] == str[i - len[i]]) { len[i]++; } if (len[i] + i > mx) { id = i; mx = len[i] + i; if (len[i] > max) { max = len[i]; index = i; } } } return s.substr((index - max) / 2, max - 1) };