注:
题目:
给你一个字符串 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:
//中心拓展过程
pair<int,int> find(string s,int i,int j){
int left=i;
int right=j;
while(left>=0&&right<s.size()&&s[left]==s[right]){
left--;
right++;
}
return make_pair(left+1,right-1);
}
string longestPalindrome(string s) {
int len=0;
string res;
for(int i=0;i<s.size();i++){
auto [left1,right1]=find(s,i,i);
auto [left2,right2]=find(s,i,i+1);
if(right1-left1+1>len){
len=right1-left1+1;
res=s.substr(left1,right1-left1+1);
}
if(right2-left2+1>len){
len=right2-left2+1;
res=s.substr(left2,right2-left2+1);
}
}
return res;
}
};