DP | 53 516.最长回文子序列

本文记录的是刷题过程中的重要概念和笔记。如有侵权,请联系删除。

目录

  • 516.最长回文子序列
  • 思路
    • DP五部曲
      • 1.确定dp数组(dp table)以及下标的含义
      • 2.递推公式
      • 3.dp数组初始化
      • 4.遍历顺序
      • 5.举例推导

516.最长回文子序列

力扣题目链接(opens new window)

给定一个字符串 s ,找到其中最长的回文子序列,并返回该序列的长度。可以假设 s 的最大长度为 1000 。

示例 1: 输入: “bbbab” 输出: 4 一个可能的最长回文子序列为 “bbbb”。

示例 2: 输入:“cbbd” 输出: 2 一个可能的最长回文子序列为 “bb”。

提示:

1 <= s.length <= 1000
s 只包含小写英文字母

思路

回文子串是要连续的,回文子序列可不是连续的!

DP五部曲

1.确定dp数组(dp table)以及下标的含义

dp[i][j]:字符串s在[i, j]范围内最长的回文子序列的长度为dp[i][j]。

2.递推公式

if (s[i] == s[j]) {
    dp[i][j] = dp[i + 1][j - 1] + 2;
} else {
    dp[i][j] = max(dp[i + 1][j], dp[i][j - 1]);
}

3.dp数组初始化

当i与j相同,那么dp[i][j]一定是等于1的

4.遍历顺序

DP | 53 516.最长回文子序列_第1张图片
从下到上遍历,从左向右遍历。

5.举例推导

class Solution {
public:
    int longestPalindromeSubseq(string s) {
        vector<vector<int>> dp(s.size(), vector<int>(s.size(), 0));
        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++) {
                if (s[i] == s[j]) {
                    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][s.size() - 1];
    }
};

你可能感兴趣的:(力扣刷题集,算法,动态规划,leetcode,数据结构,c++)