给你一个字符串 s
,找到 s
中最长的 回文子串
。思路:
对于第i个字符,可能的回文子串构成方式有两种,一种是以i位置元素为中心元素,向着两边扩展,一种是以i位置和i+1位置元素为中心,分别向两边扩展。因此对于每个字符i,按照上述两种方式分别求出以当前位置为中心的最长回文字串,然后判断最长是哪个即可。
class Solution {
public:
string longestPalindrome(string s) {
int n = s.size();
if (n == 1)
return s;
int ret = 0;
string ssret;
for (int i = 0; i < n; i++)
{
int j = 1;
int len1 = 1;
while (i - j >= 0 && i + j < n && s[i - j] == s[i + j])
{
len1 += 2;
j++;
}
j = 0;
int len2 = 0;
while (i - j >= 0 && i + 1 + j < n && s[i - j] == s[i + j+1])
{
len2+=2;
j++;
}
if (len1 > len2)
{
if (ret < len1)
{
ssret = s.substr(i - len1 / 2, len1);
ret = len1;
}
}
else
{
if (ret < len2)
{
ssret = s.substr(i + 1 - len2 / 2, len2);
ret = len2;
}
}
}
return ssret;
}
};