lintcode 667 · 最长的回文序列【中等 递归到动态规划】

题目

https://www.lintcode.com/problem/667/

java 复制代码
给一字符串 s, 找出在 s 中的最长回文子序列的长度. 你可以假设 s 的最大长度为 1000.

样例
样例1

输入: "bbbab"
输出: 4
解释:
一个可能的最长回文序列为 "bbbb"
样例2

输入: "bbbbb"
输出: 5

思路

复制代码
	思路1:运用最长公共子序列的方法来做,假设求字符串s1的最长回文子序列,
	我们先把s1反转得到字符串s2,求的s1和s2的最长公共子序列就是答案
	
	思路2: 看下面的答案

参考代码

java 复制代码
public class Solution {
    /**
     * @param s: the maximum length of s is 1000
     * @return: the longest palindromic subsequence's length
     */
    public int longestPalindromeSubseq(String s) {
           if(s ==null || s.length() ==0) return 0;

        char[] str = s.toCharArray();
        //return f(str,0,str.length-1); //递归,超时
        return f2(str); //动态规划1,可以通过
    }

    public static int f(char[] str,int L,int R){
        if(L==R) return 1;
        if(L== R-1){
            return str[L] == str[R]? 2:1;
        }

        int p1 = f(str,L+1,R-1);
        int p2 = f(str,L,R-1);
        int p3 = f(str,L+1,R);
        int p4 = str[L] != str[R] ? 0:(2+f(str,L+1,R-1));

        int ans = Math.max(Math.max(p1,p2),Math.max(p3,p4));

        return ans;
    }


    public static int f2(char[] str){
        int n = str.length;
        int[][] dp = new int[n][n];
        dp[n-1][n-1]=1;
        for (int i = 0; i <n-1 ; i++) {
            dp[i][i] =1;
            dp[i][i+1] = str[i] == str[i+1]?2:1;
        }

        for (int i = n-3; i >=0 ; i--) {
            for (int j = i+2; j <n ; j++) {
                int p1 = dp[i+1][j-1];
                int p2 = dp[i][j-1];
                int p3 = dp[i+1][j];
                int p4 = str[i]!=str[j]?0:(2+dp[i+1][j-1]);

                dp[i][j] =Math.max(Math.max(p1,p2),Math.max(p3,p4));
            }
        }
        return dp[0][n-1];
    }
}
相关推荐
黄昏ivi1 小时前
电力系统最小惯性常数解析
算法
独家回忆3641 小时前
每日算法-250425
算法
烁3471 小时前
每日一题(小白)模拟娱乐篇33
java·开发语言·算法
Demons_kirit2 小时前
LeetCode 2799、2840题解
算法·leetcode·职场和发展
软行2 小时前
LeetCode 每日一题 2845. 统计趣味子数组的数目
数据结构·c++·算法·leetcode
永远在Debug的小殿下2 小时前
查找函数【C++】
数据结构·算法
我想进大厂2 小时前
图论---染色法(判断是否为二分图)
数据结构·c++·算法·深度优先·图论
油泼辣子多加2 小时前
【风控】稳定性指标PSI
人工智能·算法·金融
雾月553 小时前
LeetCode 1292 元素和小于等于阈值的正方形的最大边长
java·数据结构·算法·leetcode·职场和发展
知来者逆5 小时前
计算机视觉——速度与精度的完美结合的实时目标检测算法RF-DETR详解
图像处理·人工智能·深度学习·算法·目标检测·计算机视觉·rf-detr