Leetcode 5——最长回文子串

先附上代码:

复制代码
class Solution {
public:
    string longestPalindrome(string s) {
    int count = s.size();
    int max = 0;
    string result;
    int j;
    int curlen;
    
    for (int i = 0; i < count; ++i)
    {
        // 如果i为奇数对称
        for (j = 0; (i-j>=0) && (i+j<count); j++)
        {
            if (s[i-j] != s[i+j])
            {
                break;
            }

            curlen = 2 * j + 1;
            if (curlen > max)
            {
                max = curlen;
                result = string(s, i-j, max);
            }    
        }

        // 如果i为偶数对称
        j = 0;
        for(j = 0; (i-j>=0) && (i+j+1 < count); ++j)
        {
            if (s[i-j] != s[i+j+1])
            {
                break;
            }
            curlen = 2*j + 2;
            if (curlen > max)
            {
                max = curlen;
                result = string(s, i-j, max);
            }
        }
    }
    return result;
    }
};
复制代码

 

按照书上说的,这种解法叫做中心扩展法,还有一种Manacher算法,有些看不懂,所以,先使用中心扩展法求解最大回文子串。

分类:区分奇数还是偶数;

思路:对每个元素进行遍历,将每个元素作为中心点向两边推进,推进的长度设定step,那么子串长度为2*step+2或2*step+1;始终记录最大长度,并保存相应字符串;

 

posted @   绍荣  阅读(161)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示