- 最长回文子串
给你一个字符串 s,找到 s 中最长的回文子串。
示例 1:
输入:s = “babad”
输出:“bab”
解释:“aba” 同样是符合题意的答案。
示例 2:
输入:s = “cbbd”
输出:“bb”
示例 3:
输入:s = “a”
输出:“a”
示例 4:
输入:s = “ac”
输出:“a”
提示:
1 <= s.length <= 1000
s 仅由数字和英文字母(大写和/或小写)组成
思路
判断回文串左右指针两边向中间收缩,得到最长回文串从中间向两边伸展。
代码
class Solution {
public String longestPalindrome(String s) {
String res = "";
for(int i = 0; i < s.length(); ++i) {
String res1 = getLongestP(s, i, i);
String res2 = getLongestP(s, i, i + 1);
res = res1.length() > res.length() ? res1 : res;
res = res2.length() > res.length() ? res2 : res;
}
return res;
}
String getLongestP(String s, int i, int j) {
int n = s.length();
while(i >= 0 && j < n && s.charAt(i) == s.charAt(j)) {
i--; j++;
}
return s.substring(i + 1, j);
}
}