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);
    }
};
相关推荐
Remember_9931 天前
【LeetCode精选算法】滑动窗口专题一
java·数据结构·算法·leetcode·哈希算法
Lueeee.1 天前
v4l2驱动开发
数据结构·驱动开发·b树
小饼干超人1 天前
详解向量数据库中的PQ算法(Product Quantization)
人工智能·算法·机器学习
你撅嘴真丑1 天前
第四章 函数与递归
算法·uva
漫随流水1 天前
leetcode回溯算法(77.组合)
数据结构·算法·leetcode·回溯算法
玄冥剑尊1 天前
动态规划入门
算法·动态规划·代理模式
mjhcsp1 天前
P14987 全等(mjhcsp)
算法·题解·洛谷
(❁´◡`❁)Jimmy(❁´◡`❁)1 天前
Atcoder abc441A~F 题解
算法·深度优先·图论
少林码僧1 天前
2.30 传统行业预测神器:为什么GBDT系列算法在企业中最受欢迎
开发语言·人工智能·算法·机器学习·ai·数据分析
豆沙沙包?1 天前
2026年--Lc343-1926. 迷宫中离入口最近的出口(图 - 广度优先搜索)--java版
java·算法·宽度优先