leecode5 最长回文子串
【摘要】 给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。
示例 1:
输入: "babad" 输出: "bab" 注意: "aba" 也是一个有效答案。 示例 2:
输入: "cbbd" 输出: "bb"
思路:
马拉车算法,不会的翻我博客的最早的文章。
只是要记录一下答案是在哪个中心取到的,方便取串。
class So...
给定一个字符串 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);
-
}
-
}
文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。
原文链接:fantianzuo.blog.csdn.net/article/details/103249571
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)