【字符串】Leetcode 最长回文子串

题目讲解

5. 最长回文子串


算法讲解

dp[i][j]表示i~j这一段区间的子串是否是回文

当s[i] == s[j]的时候,此时是有三种情况的:

i==j说明一个字符肯定是回文

i+1 == j也说明一个字符是回文

i+1 < j说明需要判断[i+1, j-1]这一段区间是否是回文

此时我们就可以明白s[i] == s[j]它仅仅判断的是左右两个端点

cpp 复制代码
class Solution {
public:
    string longestPalindrome(string s) {
        //dp[i][j]表示i~j位置的子串是否是回文串
        int n = s.size();
        int len = 1, begin = 0;
        vector<vector<bool>>dp(n, vector<bool>(n));
        for(int i = n-1; i >= 0; i--)
        {
            for(int j = i; j < n; j++)
            {
                if(s[i] == s[j])
                    dp[i][j] = i + 1 < j ? dp[i+1][j-1] : true;
                if(dp[i][j] && j-i+1 > len)
                {
                    len = j-i+1;
                    begin = i;
                }
            }
        }
        return s.substr(begin, len);
    }
};
相关推荐
刘永鑫Adam2 分钟前
BiB | 蒋超实验室开发 Kun-peng(鲲鹏):实现可扩展且准确的泛域宏基因组分类
人工智能·算法·机器学习·分类·数据挖掘
ltl7 分钟前
SM3 vs SHA-256:两个哈希函数的设计哲学与性能实测
后端·算法
知星小度S12 分钟前
算法训练之递归(一)
数据结构·算法
未来之窗软件服务17 分钟前
SenseVoicecpp ggml-webgpu大模型[AI人工智能(七十五)]—东方仙盟
c++·人工智能·算法·仙盟创梦ide·东方仙盟
ZPC821030 分钟前
ROS 2 手眼标定完整方案
人工智能·算法·性能优化·机器人
Q741_14743 分钟前
每日一题 力扣 3418. 机器人可以获得的最大金币数 力扣 215. 数组中的第K个最大元素 动态规划 TopK问题 C++ 题解
c++·算法·leetcode·动态规划·topk
Frostnova丶1 小时前
LeetCode 3418.机器人可以获得的最大金币数
算法·leetcode
寻寻觅觅☆1 小时前
东华OJ-基础题-31-素数(C++)
开发语言·c++·算法
仟濹1 小时前
【算法打卡day36(2026-04-02 周四)】DFS专项训练3
算法·深度优先
B1acktion1 小时前
2.3.插入排序——像打牌一样整理数组,为什么它对“几乎有序”数据特别友好?
数据结构·算法·排序算法