您的位置:首页 > 游戏 > 手游 > 力扣题解(最长回文子串)

力扣题解(最长回文子串)

2024/10/7 2:29:54 来源:https://blog.csdn.net/yyssas/article/details/140401169  浏览:    关键词:力扣题解(最长回文子串)

5. 最长回文子串

给你一个字符串 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;}
};

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com