给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。
示例 1:
输入: "babad"
输出: "bab"
注意: "aba" 也是一个有效答案。
示例 2:
输入: "cbbd"
输出: "bb"
一、中心扩散法:
这道题第一个想到的方法是从中心扩散,从中心扩散需要考虑三种情况:
- 字符串为空
- 字符串长度为1
- 字符串长度大于1
其中,字符串长度大于1时,需要考虑从中心扩散的两种情况,例如,"babbcbbaa" 和"abbccd"两种情况,也就是以字符为中心扩散和以字符间隙扩散。
中心扩散法:
class Solution {
public String longestPalindrome(String s) {
int maxLen = 1;
String maxString = "";
if(s.length() < 2){
return s;
}
String res = s.substring(0,1);
for(int i = 0; i < s.length()-1; i++){
//由中心扩散,考虑两种情况(奇数扩散和偶数扩散)
String oddString = centerSpread(s,i,i);
String evenString = centerSpread(s,i,i+1);
if(oddString.length() > evenString.length()){
maxString = oddString;
}
else{
maxString = evenString;
}
if(maxString.length() > maxLen){
maxLen = maxString.length();
res = maxString;
}
}
return res;
}
private String centerSpread(String s,int left, int right){
int s_len = s.length();
while(left >= 0 && right < s_len){
if(s.charAt(left) == s.charAt(right)){
left--;
right++;
}
else{
break;
}
}
return s.substring(left+1,right);
}
}