力扣--动态规划516.最长回文子序列

思路分析:

  1. 创建一个二维动态规划表dp,其中dp[i][j]表示在子串s[i...j]中的最长回文子序列的长度。
  2. 初始化基本情况:对角线上的元素dp[i][i]都为1,因为单个字符本身就是长度为1的回文子序列。
  3. 从字符串末尾向前遍历,填充动态规划表。对于每一对(i, j),如果s[i]等于s[j],则当前子串的最长回文子序列长度为dp[i + 1][j - 1] + 2,否则取dp[i + 1][j]dp[i][j - 1]中的较大值。
  4. 最终结果存储在dp[0][s.size() - 1]中,表示整个字符串s的最长回文子序列的长度。
cpp 复制代码
class Solution {
public:
    // 计算最长回文子序列的长度
    int longestPalindromeSubseq(string s) {
        // 创建二维动态规划表,dp[i][j]表示子串s[i...j]的最长回文子序列长度
        vector<vector<int>> dp(s.size(), vector<int>(s.size(), 0));

        // 初始化基本情况:单个字符本身就是长度为1的回文子序列
        for (int i = 0; i < s.size(); i++) {
            dp[i][i] = 1;
        }

        // 自底向上填充动态规划表
        // 从字符串末尾向前遍历
        for (int i = s.size() - 1; i >= 0; i--) {
            for (int j = i + 1; j < s.size(); j++) {
                // 如果s[i]等于s[j],当前子串的最长回文子序列长度为dp[i + 1][j - 1] + 2
                if (s[i] == s[j]) {
                    dp[i][j] = dp[i + 1][j - 1] + 2;
                } else {
                    // 否则,取dp[i + 1][j]和dp[i][j - 1]中的较大值
                    dp[i][j] = max(dp[i + 1][j], dp[i][j - 1]);
                }
            }
        }

        // 最终结果存储在dp[0][s.size() - 1]中,表示整个字符串s的最长回文子序列长度
        return dp[0][s.size() - 1];
    }
};
相关推荐
机器学习之心6 分钟前
PSO-LightGBM-ABKDE粒子群算法优化轻量级梯度提升机自适应带宽核密度估计多变量回归区间预测Matlab实现
算法·matlab·回归·abkde·自适应带宽核密度估计·pso-lightgbm·粒子群算法优化轻量级梯度提升机
qq_4160187220 分钟前
分布式缓存一致性
开发语言·c++·算法
CoovallyAIHub25 分钟前
多 Agent 手术推理框架:Agent 辩论+RAG 补上手术知识,零样本超越监督基线 14.6 个百分点
算法·架构·机器人
干啥啥不行,秃头第一名29 分钟前
STL容器内部实现剖析
开发语言·c++·算法
Zarek枫煜29 分钟前
zig与c3的冒泡排序算法
算法
xiaoye-duck33 分钟前
《算法题讲解指南:动态规划算法--简单多状态dp问题》--13.删除并获得点数,14.粉刷房子
c++·算法·动态规划
老鼠只爱大米34 分钟前
LeetCode经典算法面试题 #347:前 K 个高频元素(最小堆、桶排序、快速选择等多种实现方案详解)
算法·leetcode·堆排序·java面试题·桶排序·快速选择·topk
2401_8318249636 分钟前
内存泄漏检测与防范
开发语言·c++·算法
FluxMelodySun1 小时前
机器学习(二十五) 降维:主成分分析(PCA)及特征值分解
人工智能·算法·机器学习
liuyao_xianhui1 小时前
优选算法_分治_快速排序_归并排序_C++
开发语言·数据结构·c++·算法·leetcode·排序算法·动态规划