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];
    }
}
相关推荐
_GR11 分钟前
每日OJ题_牛客_牛牛冲钻五_模拟_C++_Java
java·数据结构·c++·算法·动态规划
ROBIN__dyc23 分钟前
表达式
算法
无限大.27 分钟前
c语言实例
c语言·数据结构·算法
六点半88831 分钟前
【C++】速通涉及 “vector” 的经典OJ编程题
开发语言·c++·算法·青少年编程·推荐算法
@haihi40 分钟前
冒泡排序,插入排序,快速排序,选择排序
数据结构·算法·排序算法
quaer43 分钟前
Open-Sora全面开源?
开发语言·算法·机器学习·matlab·矩阵
Hello.Reader1 小时前
TopK算法在大数据重复数据分析中的应用与挑战
大数据·算法·数据分析
coduck_S12004zbj1 小时前
csp-j模拟五补题报告
c++·算法·图论
洛临_1 小时前
【C语言】基础篇
c语言·算法
_.Switch1 小时前
Python机器学习模型的部署与维护:版本管理、监控与更新策略
开发语言·人工智能·python·算法·机器学习