【力扣05】最长回文子串

0. 引言

●子串(substring):原始字符串的一个连续子集;

●子序列(subsequence):原始字符串的一个子集。

1. 什么叫回文串

如果一个字符串正着读和反着读是一样的,那它就是回文串。[1]

例如,字符串"apapa"无论从左到右还是从右到左读取,结果均为"apapa"。以下是回文串的核心特性:

  1. 对称性

    回文串的字符序列以中心为对称轴镜像对称。若字符串长度为奇数(如"radar"),对称轴是中间字符;若长度为偶数(如"abba"),对称轴位于中间两个字符之间。

假如回文的中心为 双数,例如 abba,对称轴是中间字符为 a bba,

假为回文的中心为 单数,例如 abbabde, 对称轴是中间字符为a b b ab d e,

  1. 字符位置对应

    对于长度为n的回文串,第i个字符与第n−i+1个字符必须相同(1≤i≤n)。例如,字符串"noon"中,第1个字符"n"与第4个字符"n"对应,第2个字符"o"与第3个字符"o"对应。

  2. 长度无关性

    回文串的长度可以是任意正整数,包括长度为1的字符(如"a")或空字符串(通常也被视为回文)。

2. 代码实现

复制代码
	string longestPalindrome(string s) 
	{
		if (s.length() < 1)
		{
			return "";
		}
		int start = 0, end = 0;
		for (int i = 0; i < s.length(); i++)
		{
			int len1 = expandAroundCenter(s, i, i);//一个元素为中心
			int len2 = expandAroundCenter(s, i, i + 1);//两个元素为中心
			int len = max(len1, len2);
			if (len > end - start)
			{
				start = i - (len - 1) / 2;
				end = i + len / 2;
			}
		}
		return s.substr(start, end - start + 1);
	}

	int expandAroundCenter(string s, int left, int right)
	{
		int L = left, R = right;
		while (L >= 0 && R < s.length() && s[L] == s[R])
		{// 计算以left和right为中心的回文串长度
			L--;
			R++;
		}
		return R - L - 1;
	}

3. 逐行解析

cpp 复制代码
string longestPalindrome(string s) 
{
  • 功能 :主函数,输入字符串s,返回其中最长的回文子串。
cpp 复制代码
if (s.length() < 1)
{
    return "";
}
  • 解释:如果字符串长度小于1(即为空),直接返回空字符串。
cpp 复制代码
int start = 0, end = 0;
  • 功能startend用于记录当前找到的最长回文子串的起始和结束索引。
cpp 复制代码
for (int i = 0; i < s.length(); i++)
{
    int len1 = expandAroundCenter(s, i, i); // 奇数长度回文中心
    int len2 = expandAroundCenter(s, i, i + 1); // 偶数长度回文中心
    int len = max(len1, len2);
  • 功能 :对每个字符i,分别计算以它为中心的奇数长度回文(len1)和以它及其下一个字符为中心的偶数长度回文(len2),取两者中的较大值作为当前中心的最大回文长度。
cpp 复制代码
if (len > end - start)
{
    start = i - (len - 1) / 2;
    end = i + len / 2;
}
  • start:计算当前回文的起始位置。对于长度为len,中心点在i处,起始位置为i - (len-1)/2
  • end:计算当前回文的结束位置,为i + len / 2
cpp 复制代码
int expandAroundCenter(string s, int left, int right)
{
    int L = left, R = right;
    while (L >= 0 && R < s.length() && s[L] == s[R])
    {
        L--;
        R++;
    }
    return R - L - 1;
}
  • 功能 :以leftright为左右中心,向两边扩展,计算最长回文的长度。
  • 过程
    • 初始时,L = left, R = right.
    • s[L] == s[R]且未超出字符串边界时,继续向外扩展。
    • 循环结束后,返回当前回文长度:R - L - 1.

参考文献

1\][最长回文子串 C / C++](https://leetcode.cn/problems/longest-palindromic-substring/solutions/7600/5-zui-chang-hui-wen-zi-chuan-cc-by-bian-bian-xiong/ "最长回文子串 C / C++")

相关推荐
广州灵眸科技有限公司3 分钟前
瑞芯微(EASY EAI)RV1126B AI算法开发流程
人工智能·算法·机器学习
Rabitebla1 小时前
【C++】string 类:原理、踩坑与对象语义
linux·c语言·数据结构·c++·算法·github·学习方法
小雅痞2 小时前
[Java][Leetcode middle] 167. 两数之和 II - 输入有序数组
java·算法·leetcode
CN-Dust2 小时前
【C++】输入cin例题专题
java·c++·算法
数模竞赛Paid answer3 小时前
2025年MathorCup数学建模A题汽车风阻预测解题文档与程序
算法·数学建模·mathorcup
xin_nai3 小时前
LeetCode热题100(Java)(6)矩阵
java·leetcode·矩阵
一只幸运猫.9 小时前
2026Java 后端面试完整版|八股简答 + AI 大模型集成技术(最新趋势)
人工智能·面试·职场和发展
Old Uncle Tom9 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆9 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移9 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言