当前位置: 首页 > news >正文

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

题目

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

给一字符串 s, 找出在 s 中的最长回文子序列的长度. 你可以假设 s 的最大长度为 1000.样例
样例1输入: "bbbab"
输出: 4
解释:
一个可能的最长回文序列为 "bbbb"
样例2输入: "bbbbb"
输出: 5

思路

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

参考代码

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];}
}
http://www.lryc.cn/news/153041.html

相关文章:

  • oracle sql语言模糊查询
  • 【Ubuntu】解决ubuntu虚拟机和物理机之间复制粘贴问题(无需桌面工具)
  • 解决ubuntu文件系统变成只读的方法
  • 高数刷题笔记
  • c++入门一
  • 2023年项目进度管理平台排行榜
  • 【设计模式】面向对象设计八大原则
  • python数分实战探索霍尔特法之销售预测python代码实现以及预测图绘制
  • java线程状态
  • 编译问题:error: ‘printf’ was not declared in this scope
  • 改变C++中私有变量成员的值
  • 线程唯一的单例
  • 明厨亮灶监控实施方案 opencv
  • 14 mysql bit/json/enum/set 的数据存储
  • 04_19linux自己撸内存池实战,仿造slab分配器
  • 【HDFS】XXXRpcServer和ClientNamenodeProtocolServerSideTranslatorPB小记
  • 二分,Dijkstra,340. 通信线路
  • Stable Diffusion---Ai绘画-下载-入门-进阶(笔记整理)
  • Java 乘等赋值运算
  • 【性能优化】聊聊性能优化那些事
  • k8s 查看加入主节点命令 k8s重新查看加入节点命令 k8s输入删除,重新查看加入命令 kuberadm查看加入节点命令
  • Scalene:Python CPU+GPU+内存分析器,具有人工智能驱动的优化建议
  • C语言练习8(巩固提升)
  • Java匿名内部类
  • Shiro和SpringSecurity的区别
  • 【STM32】学习笔记(OLED)
  • 概念解析 | 认知雷达:有大脑的雷达
  • B. Long Long
  • CTFhub-文件上传-.htaccess
  • Python中的绝对和相对导入