[LeetCode]516. 最长回文子序列[记忆化搜索解法详解]

最长回文子序列

LeetCode 原题链接

题目

给你一个字符串 `s` ,找出其中最长的回文子序列,并返回该序列的长度。

子序列定义为:不改变剩余字符顺序的情况下,删除某些字符或者不删除任何字符形成的一个序列。

示例 1

输入 :s = "bbbab"
输出 :4
解释:一个可能的最长回文子序列为 "bbbb" 。

示例 2:

输入 :s = "cbbd"
输出 :2
解释:一个可能的最长回文子序列为 "bb" 。

提示

  • 1 <= s.length <= 1000
  • s 仅由小写英文字母组成

状态表示

  • dp[i][j]表示从索引i~j区间的字符的最大回文子串。

状态转移方程

si!=sj

  • dfs[i][j] = max(dfs[i+1][j], dfs[i][j-1])

si==sj

  • dfs[i][j] = dfs[i+1][j-1]+2

推导过程

LeetCode 代码

c 复制代码
class Solution {
public:
    string st;
    vector<vector<int>> memo;
    int longestPalindromeSubseq(string s) {
        st = s;
        int n = s.size();
        memo.resize(n, vector<int>(n, -1));
        return dfs(0, n-1);
    }
    inline int dfs(int i, int j) {
        if (i > j) return 0;
        if (i == j) return 1;
        int &res = memo[i][j];
        if (res != -1) return res;
        if (st[i] == st[j]) {
            return res = 2 + dfs(i+1, j-1);
        } else {
            return res = max(dfs(i+1, j), dfs(i, j-1));
        }
    }
};
相关推荐
想吃火锅100515 分钟前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
云絮.1 小时前
数据库操作
数据库·mysql·算法·oracle
小林ixn2 小时前
LeetCode 206. 反转链表(迭代 + 递归详解)
算法·leetcode·链表
凡人叶枫2 小时前
Effective C++ 条款17:以独立语句将 newed 对象置入智能指针
java·linux·开发语言·c++·算法
菜鸟‍3 小时前
LeetCode 1 27 和 704 || 两数之和 移除元素 二分查找
算法·leetcode·职场和发展
退休倒计时4 小时前
【每日一题】LeetCode 142. 环形链表 II TypeScript
算法·leetcode·链表·typescript
popcorn_min5 小时前
Digits 手写数字识别:随机森林多分类 + 像素级特征热力图
算法·随机森林·分类
liulilittle5 小时前
拥塞控制:排水终止的两种决策:OR 与 AND
网络·tcp/ip·计算机网络·算法·信息与通信·tcp·通信
weixin_307779136 小时前
从脚本执行到智能体协作:AI辅助测试能力的范式重构
运维·开发语言·人工智能·算法·测试用例
量化君也6 小时前
从回测到全自动实盘交易,全天候策略需要经历哪些改造?
大数据·人工智能·python·算法·金融