博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode 516. Longest Palindromic Subsequence
阅读量:4965 次
发布时间:2019-06-12

本文共 2347 字,大约阅读时间需要 7 分钟。

516. Longest Palindromic Subsequence

  

  • Total Accepted: 2159
  • Total Submissions: 5216
  • Difficulty: Medium
  • Contributors: 

 Given a string s, find the longest palindromic subsequence's length in s. You may assume that the maximum length of s is 1000.

Example 1:

Input:

"bbbab"
Output:
4
One possible longest palindromic subsequence is "bbbb".

 Example 2:

Input:

"cbbd"
Output:
2
One possible longest palindromic subsequence is "bb". 

 to see which companies asked this question.

【题目分析】

给定一个字符串,返回字符串中包含的最长的回文子串。

【思路】

这是一个动态规划的题目,对于动态规划的题目,我们首先要明确这个大问题如何用子问题来表示,然后分情况写出动态规划的递归表达式,这样编程实现就简单多了。

1. 子问题的解如何表达?

给定一个字符串,把它划分成什么样的子问题呢?通过分析我们发现,这样的子问题是:任意一个该字符串的子串包含的回文串的长度,那么对于这个字符串的子串,我们可以用它在原字符串中的起始位置和结束位置来表示。因此,我们可以用一个二维数组来对子问题进行表示,dp[i][j]表示he longest palindromic subsequence's length of substring(i, j)。

2. 大问题如何用子问题来表示?

dp[i][j] = dp[i+1][j-1] + 2 if s.charAt(i) == s.charAt(j)

otherwise, dp[i][j] = Math.max(dp[i+1][j], dp[i][j-1])
Initializationdp[i][i] = 1

通过上面的分析,我们已经知道了该如何解决这个问题。

【java代码】——循环的方式

1 public class Solution { 2     public int longestPalindromeSubseq(String s) { 3         int len = s.length(); 4         int[][] dp = new int[len][len]; 5          6         for(int i = len-1; i >= 0; i--) { 7             dp[i][i] = 1; 8             for(int j = i+1; j < len; j++) { 9                 if(s.charAt(i) == s.charAt(j)) {10                     dp[i][j] = dp[i+1][j-1] + 2;11                 }12                 else {13                     dp[i][j] = Math.max(dp[i+1][j], dp[i][j-1]);14                 }15             }16         }17         18         return dp[0][len-1];19     }20 }

 【java代码】——递归的方式(效率很高)

1 public class Solution { 2     public int longestPalindromeSubseq(String s) { 3         return helper(s, 0, s.length() - 1, new int[s.length()][s.length()]); 4     } 5      6     private int helper(String s, int i, int j, int[][] memo) { 7         if (memo[i][j] != 0) { 8             return memo[i][j]; 9         }10         if (i > j)      return 0;11         if (i == j)     return 1;12         13         if (s.charAt(i) == s.charAt(j)) {14             memo[i][j] = helper(s, i + 1, j - 1, memo) + 2;15         } else {16             memo[i][j] = Math.max(helper(s, i + 1, j, memo), helper(s, i, j - 1, memo));17         }18         return memo[i][j];19     }20 }

 

转载于:https://www.cnblogs.com/liujinhong/p/6418192.html

你可能感兴趣的文章
cocos2dx-3.0(8)------Label、LabelTTF、LabelAtlas、LabelBMFont使用之法
查看>>
CODE[VS] 1842 递归第一次
查看>>
20180418小测
查看>>
数字三角形
查看>>
NGUI 减少drawcall规则
查看>>
三元表达,匿名函数
查看>>
前端笔记-基础笔记
查看>>
【LeetCode & 剑指offer刷题】查找与排序题6:33. Search in Rotated Sorted Array(系列)
查看>>
GNU/Linux超级本ZaReason Ultralap 440体验
查看>>
将github上托管的代码 在我的域名下运行
查看>>
【Manthan, Codefest 18 (rated, Div. 1 + Div. 2) C】Equalize
查看>>
【codeforces 767A】Snacktower
查看>>
【MemSQL Start[c]UP 3.0 - Round 1 C】 Pie Rules
查看>>
Ognl中“%”、“#”、“$”详解
查看>>
我对应用软件——美团的看法
查看>>
执行了的程序,才是你的程序.
查看>>
struts2.x + Tiles2.x读取多个xml 配置文件
查看>>
表单校验之datatype
查看>>
python第六篇文件处理类型
查看>>
hdu 3183 A Magic Lamp 贪心
查看>>