C++ | Leetcode C++题解之第516题最长回文子序列

题目:

题解:

cpp 复制代码
class Solution {
public:
    int longestPalindromeSubseq(string s) {
        int n = s.length();
        vector<vector<int>> dp(n, vector<int>(n));
        for (int i = n - 1; i >= 0; i--) {
            dp[i][i] = 1;
            char c1 = s[i];
            for (int j = i + 1; j < n; j++) {
                char c2 = s[j];
                if (c1 == c2) {
                    dp[i][j] = dp[i + 1][j - 1] + 2;
                } else {
                    dp[i][j] = max(dp[i + 1][j], dp[i][j - 1]);
                }
            }
        }
        return dp[0][n - 1];
    }
};
相关推荐
智者知已应修善业9 分钟前
【51单片机非精准计时2个外部中断启停】2023-5-29
c++·经验分享·笔记·算法·51单片机
沐雪轻挽萤14 分钟前
3. C++17新特性-带初始化的 if 和 switch 语句
开发语言·c++
Magic--1 小时前
C++ 智能指针
开发语言·c++·算法
呱呱巨基1 小时前
网络基础概念
linux·网络·c++·笔记·学习
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.11):三个相等元素之间的最小距离 II
算法·leetcode
飞鼠_1 小时前
详解c++中的sturct
开发语言·c++
CoderCodingNo1 小时前
【GESP】C++一级真题 luogu-B4495, [GESP202603 一级] 交朋友
开发语言·c++
梦游钓鱼2 小时前
stl常用容器说明
开发语言·c++
WBluuue2 小时前
Codeforces 1088 Div1+2(ABC1C2DEF)
c++·算法
蓝色的杯子2 小时前
Python面试30分钟突击掌握-LeetCode3-Linked list
python·leetcode·面试