leetcode 5. 最长回文子串

2023.9.12

本题和 回文子串 类似,看到回文子串相关题目就应该联想起来。思想差不多,但题目要求返回最长的回文子串,所以需要定义两个全局变量:max_length用于记录当前最长回文子串的长度,start用于记录当前最长回文子串的起始索引。 方便最后用substr返回该最长回文子串。

代码如下:

cpp 复制代码
class Solution {
public:
    string longestPalindrome(string s) {
        vector<vector<bool>> dp(s.size(),vector<bool>(s.size(),false));
        int max_length = 0;
        int start = 0;
        for(int i=s.size()-1; i>=0; i--)
        {
            for(int j=i; j<s.size(); j++)
            {
                if(s[i] == s[j])
                {
                    if(j - i <= 1) dp[i][j] = true;
                    else dp[i][j] = dp[i+1][j-1];
                }
                if(dp[i][j] && j-i+1 > max_length) 
                {
                    start = i;
                    max_length = j-i+1;
                }
            }
        }
        return s.substr(start,max_length);
    }
};
相关推荐
木斯佳2 分钟前
前端八股文面经大全:京东零售JDY前端一面(2026-04-14)·面经深度解析
前端·算法·设计模式·ai·断点续传
zore_c2 分钟前
【C++】C++——类的默认成员函数(构造、析构、拷贝构造函数)
java·c语言·c++·笔记·算法·排序算法
进击的荆棘5 分钟前
C++起始之路——AVL树的实现
开发语言·数据结构·c++·stl·avl
生信研究猿5 分钟前
第2题-模型推理量化加速优化问题
python·算法
进击的荆棘7 分钟前
C++起始之路——红黑树的实现
开发语言·数据结构·c++·stl·红黑树
菜择贰8 小时前
B树的性质和查找、插入、删除操作
数据结构·b树
LDR0069 小时前
接口焦虑终结者:LDR6020 芯片如何重新定义 Type-C 拓展坞与多设备互联时代
数据结构·经验分享·智能音箱
房开民10 小时前
可变参数模板
java·开发语言·算法
_深海凉_10 小时前
LeetCode热题100-最小栈
java·数据结构·leetcode
不知名的忻10 小时前
Morris遍历(力扣第99题)
java·算法·leetcode·morris遍历