给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。
示例 1:
输入: "babad"
输出: "bab"
注意: "aba" 也是一个有效答案。
示例 2:
输入: "cbbd"
输出: "bb"
思路:
马拉车算法,不会的翻我博客的最早的文章。
只是要记录一下答案是在哪个中心取到的,方便取串。
class Solution {public char[] manacherString(String str) {char[] charArr = str.toCharArray();char[] res = new char[str.length() * 2 + 1];int index = 0;for (int i = 0; i != res.length; i++) {res[i] = (i & 1) == 0 ? '#' : charArr[index++];}return res;}public int[] maxLcpsLength(String str) {if (str == null || str.length() == 0) {return new int[2];}char[] charArr = manacherString(str);int[] pArr = new int[charArr.length];int index = -1;int pR = -1;int ansIndex=-1;int max = Integer.MIN_VALUE;for (int i = 0; i != charArr.length; i++) {pArr[i] = pR > i ? Math.min(pArr[2 * index - i], pR - i) : 1;while (i + pArr[i] < charArr.length && i - pArr[i] > -1) {if (charArr[i + pArr[i]] == charArr[i - pArr[i]])pArr[i]++;else {break;}}if (i + pArr[i] > pR) {pR = i + pArr[i];index = i;}if(max<pArr[i]) {max=pArr[i];ansIndex=i;}max = Math.max(max, pArr[i]);}int[] ans=new int[2];ans[0]=max-1;ans[1]=ansIndex;return ans;}public String longestPalindrome(String s) {int[] ans=maxLcpsLength(s);return s.substring((ans[1]-ans[0])/2,(ans[1]+ans[0])/2+(ans[1]+ans[0])%2);}
}