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

题目讲解

5. 最长回文子串


算法讲解

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

当si == sj的时候,此时是有三种情况的:

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

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

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

此时我们就可以明白si == sj它仅仅判断的是左右两个端点

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);
    }
};
相关推荐
见合八方4 分钟前
【滤波器】热调谐FP滤波器
人工智能·算法
古城小栈4 分钟前
cargo-pprof:Rust性能调优
人工智能·算法·rust
x_xbx15 分钟前
LeetCode:543. 二叉树的直径
算法·leetcode·职场和发展
QiLinkOS16 分钟前
QiLink 技术委员会选举实施细则
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源
我材不敲代码19 分钟前
Python基础: 函数超全详解:定义、参数、返回值、作用域与递归
开发语言·python·算法
罗超驿25 分钟前
11.LeetCode 1004. 最大连续1的个数 III | 滑动窗口解法详解(Java)
java·算法·leetcode
QiLinkOS30 分钟前
发明人与专利价值共生逻辑
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法
计算机安禾41 分钟前
【算法分析与设计】第21篇:回溯法的状态空间树与剪枝函数设计
大数据·人工智能·算法·机器学习·数据挖掘·剪枝
磊 子42 分钟前
STL之set以及set和map区别
开发语言·c++·算法
Promise微笑1 小时前
算法突围:“双核四驱”理论下的“官网”AI引用概率提升指南
人工智能·算法·chatgpt