【LeetCode】5 . 最长回文子串

5 . 最长回文子串(中等)

方法:中心扩散法

思想

  • 「中心扩散法」的基本思想是:遍历每一个下标,以这个下标为中心,利用「回文串」中心对称的特点,往两边扩散,看最多能扩散多远。

  • 枚举「中心位置」时间复杂度为 O(N),从「中心位置」扩散得到「回文子串」的时间复杂度为 O(N),因此时间复杂度可以降到 O(N2) 。

  • 细节:回文串在长度为奇数和偶数的时候,「回文中心」的形态不一样:

    • 奇数回文串的「中心」是一个具体的字符,例如:回文串 "aba" 的中心是字符 "b";
    • 偶数回文串的「中心」是位于中间的两个字符的「空隙」,例如:回文串 "abba" 的中心是两个 "b",也可以看成两个 "b" 中间的空隙。

代码

cpp 复制代码
class Solution {
public:
    int center = 0;
    int len = 0;
    string longestPalindrome(string s) {
        for(int i=0; i<s.size(); ++i) {
            search(i, i, s);
            search(i, i+1, s);
        }
        // 计算最长子串的起始位置
        int begin = center - (len - 1) / 2;
        return s.substr(begin, len);
    }
    void search(int i, int j, string s) {
        if(i < 0 || j >= s.size())    return ;
        // 保存当前中心
        int pos = i;
        while(i >= 0 && j < s.size() && s[i] == s[j]) {
            i--;
            j++;
        }
        // 标记最长的回文子串长度及其中心
        if(j - i - 1 > len) {
            len = j - i - 1;
            center = pos;
        } 
    }
};

参考资料

  1. 动态规划、中心扩散、Manacher 算法
相关推荐
流云鹤17 小时前
2026牛客寒假算法基础集训营2(A B I F E H)
算法
大黄说说17 小时前
Go 实战 LeetCode 151:高效翻转字符串中的单词(含空格处理技巧)
开发语言·leetcode·golang
Lun3866buzha17 小时前
紧固件智能检测与分类_ATSS_R101_FPN_1x_COCO算法解析与Pytorch实现
pytorch·算法·分类
MSTcheng.17 小时前
【Leetcode二分查找】『在排序数组中查找元素的第一个和最后一个位置&搜索插入位置』
算法·leetcode·职场和发展
初夏睡觉18 小时前
笔记(动态规划(引入)1)
笔记·算法·动态规划
热爱生活的猴子18 小时前
二分查找类算法题核心笔记
数据结构·笔记·算法
大模型实验室Lab4AI18 小时前
GDPO:多目标强化学习高效优化新路径
人工智能·深度学习·算法·机器学习
小O的算法实验室18 小时前
2026年CIE SCI2区TOP,用于地质灾害监测的配备自主对接站的无人机多航次路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
仟濹18 小时前
【算法打卡day9(2026-02-14 周六)算法:并查集】 4-卡码网108-冗余连接
算法
hoiii18718 小时前
拉丁超立方抽样(LHS)的MATLAB实现:基本采样与相关采样
开发语言·算法