问题描述
Given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.
Example 1:
Input: “babad”
Output: “bab”
Note: “aba” is also a valid answer.
Example 2:
Input: “cbbd”
Output: “bb”
解法思路
利用dp[i][j]来表示以i开始j结尾的字串是否是回文串,则存在以下关系:
if(s[i]==s[j]&&dp[i+1][j-1]==true) dp[i][j]=true;表示其为回文串,根据这一关系可以解决问题。
C++代码
class Solution {
public:
string longestPalindrome(string s) {
const int len = s.size();
if(len <= 1)return s;
bool dp[len][len];//dp[i][j]表示s[i..j]是否是回文
memset(dp, 0, sizeof(dp));
int resLeft = 0, resRight = 0;
dp[0][0] = true;
for(int i = 1; i < len; i++)
{
dp[i][i] = true;
dp[i][i-1] = true;//这个初始化容易忽略,当k=2时要用到
}
for(int k = 2; k <= len; k++)//枚举子串长度
for(int i = 0; i <= len-k; i++)//枚举子串起始位置
{
if(s[i] == s[i+k-1] && dp[i+1][i+k-2])
{
dp[i][i+k-1] = true;
if(resRight-resLeft+1 < k)
{
resLeft = i;
resRight = i+k-1;
}
}
}
return s.substr(resLeft, resRight-resLeft+1);
}
};
结果分析
Runtime: 100 ms, faster than 53.49% of C++ online submissions for Longest Palindromic Substring.
比较慢,还需进一步改进!