题目:来源于leetcode
给你一个字符串 s,找到 s 中最长的回文子串。
代码:
class Solution {
public:
pair<int, int> expandAroundCenter(const string& s, int left, int right) {
while (left >= 0 && right < s.size() && s[left] == s[right]) {
--left;
++right;
}
return {left + 1, right - 1};
}
string longestPalindrome(string s) {
int start = 0, end = 0;
for (int i = 0; i < s.size(); ++i) {
auto [left1, right1] = expandAroundCenter(s, i, i);
auto [left2, right2] = expandAroundCenter(s, i, i + 1);
if (right1 - left1 > end - start) {
start = left1;
end = right1;
}
if (right2 - left2 > end - start) {
start = left2;
end = right2;
}
}
return s.substr(start, end - start + 1);
}
};
总结:
首先是很关键的中心展开函数,如果是回文数,那么从回文串的中心向两端扩散,相对的字符是一样的,不断地移动两侧节点,直到两端的字符不相等,说明回文到此为止,返回是回文串的左右两侧节点。
其次是注意到,回文串是奇数还是偶数,如果是奇数那么中心是一个字符,如果是偶数,那么中心是一个间隙,啥都没有。