LeetCode 516

https://leetcode.cn/problems/longest-palindromic-subsequence/description/

难度:中等

高频面试题汇总:https://www.yuweihung.com/posts/2025/lc-hot/

区间 DP,从大区间转移到小区间。f[i][j] 为 s[i] 到 s[j] 的最长回文子序列。

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

时间复杂度:O(n^2),其中 n 为 s 的长度。动态规划的时间复杂度 = 状态个数 × 单个状态的转移个数。本题中状态个数等于 O(n^2),而单个状态的转移个数为 O(1),因此时间复杂度为 O(n^2)。

空间复杂度:O(n^2)。

class Solution {
public:
    int longestPalindromeSubseq(string s) {
        int n = s.length();
        vector f(n, vector<int>(n));
        for (int i = n - 1; i >= 0; i--) {
            f[i][i] = 1;
            for (int j = i + 1; j < n; j++) {
                f[i][j] = s[i] == s[j] ? f[i + 1][j - 1] + 2 :
                          max(f[i + 1][j], f[i][j - 1]);
            }
        }
        return f[0][n - 1];
    }
};