LeetCode 516. 最长回文子序列

Posted 数据结构和算法

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 516. 最长回文子序列相关的知识,希望对你有一定的参考价值。

截止到目前我已经写了 500多道算法题,其中部分已经整理成了pdf文档,目前总共有1000多页(并且还会不断的增加),大家可以免费下载
下载链接https://pan.baidu.com/s/1hjwK0ZeRxYGB8lIkbKuQgQ
提取码:6666

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

public int longestPalindromeSubseq(String s) {
    int length = s.length();
    int[][] dp = new int[length][length];
    //这里i要从最后一个开始遍历
    for (int i = length - 1; i >= 0; i--) {
        //单个字符也是一个回文串
        dp[i][i] = 1;
        //j从i的下一个开始
        for (int j = i + 1; j < length; j++) {
            //下面是递推公式
            if (s.charAt(i) == s.charAt(j)) {
                dp[i][j] = dp[i + 1][j - 1] + 2;
            } else {
                dp[i][j] = Math.max(dp[i + 1][j], dp[i][j - 1]);
            }
        }
    }
    return dp[0][length - 1];
}

以上是关于LeetCode 516. 最长回文子序列的主要内容,如果未能解决你的问题,请参考以下文章

Leetcode刷题Python516. 最长回文子序列

LeetCode 516. 最长回文子序列

516. 最长回文子序列(Python)

LeetCode 516 最长回文子序列[动态规划] HERODING的LeetCode之路

516 Longest Palindromic Subsequence 最长回文子序列

LeetCode 516. 最长回文子序列(区间dp) / 36. 有效的数独/73. 矩阵置零/496. 下一个更大元素 I / 456. 132 模式(特别的单调栈)