给你一个字符串 s
,找到 s
中最长的回文子串。
方法一,暴力解法(似乎时间太长了哈哈
class Solution {
public:
bool ispalindrome(string s){
for(int i =0;i<s.size()/2;i++){
if(s[i] != s[s.size()-1-i]){
return false;
}
}
return true;
}
string longestPalindrome(string s) {
int maxlen = 0;
string ans = "";
for(int i=0;i<s.size();i++){
for(int j=1;j<=s.size()-i;j++){
string test = s.substr(i,j);
if(ispalindrome(test)&&test.size()>maxlen)
{
maxlen = test.size();
ans = test;
}
}
}
return ans;
}
};
方法二:中心扩展(很好理解,但似乎时间复杂度还是不行
class Solution {
public:
int zuichang(string s,int left,int right){
while(left>=0 && right<s.size() && s[left]==s[right]){
left--;
right++;
}
return right-left-1;
}
string longestPalindrome(string s) {
if(s.size() == 0 || s.size() == 1){
return s;
}
int maxlen = 0;
int star = 0;
int end=0;
for(int i=0;i<s.size();i++){
int len1 = zuichang(s,i,i);
int len2 = zuichang(s,i,i+1);
maxlen=max(max(len1,len2),maxlen);
if(maxlen>(end-star)+1){
star = i-(maxlen-1)/2;
end = i+maxlen/2;
}
}
return s.substr(star,maxlen);
}
};