【LeetCode】516. Longest Palindromic Subsequence 最长回文子序列
作者: 负雪明烛
id: fuxuemingzhu
个人博客: http://fuxuemingzhu.cn/
题目地址:https://leetcode.com/problems/longest-palindromic-subsequence/description/
题目描述
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".
题目大意
找出一个字符串中最长的回文序列的长度。注意序列可以是不连续的,而子字符串是连续的。
解题思路
做完昨天的每日一题 446. 等差数列划分 II - 子序列 之后,相信大家对于子序列问题的套路已经更加了解了。子序列问题不能用滑动窗口了,可以用动态规划来解决。子序列问题的经典题目就是 300. 最长递增子序列,务必掌握。
先从整体思路说起。
子序列问题,由于是数组中的非连续的一个序列,使用动态规划求解时,避免不了二重循环:第一重循环是求解动态规划的每一个状态
d
p
[
i
]
,
(
0
<
=
i
<
=
N
)
dp[i], (0 <= i <= N)
dp[i],(0<=i<=N) ,第二重循环是向前寻找上一个子序列的结尾
j
,
(
0
<
=
j
<
i
)
j ,(0 <= j < i)
j,(0<=j<i)$ 来和
i
i
i 一起构成满足题意的新的子序列。
- 对于「最长递增子序列」问题,我们对
i
,
j
i, j
i,j 的要求是
n
u
m
s
[
i
]
>
n
u
m
s
[
j
]
nums[i] > nums[j]
nums[i]>nums[j],即递增;
- 对于「能构成等差数列的子序列」问题,我们对
i
,
j
i, j
i,j 的要求是
n
u
m
[
i
]
num[i]
num[i] 可以在
n
u
m
s
[
j
]
nums[j]
nums[j] 的基础上构成等差数列。
- 对于「最长回文子序列」问题,我们对
i
,
j
i, j
i,j 本身的取值没有要求,但是希望能够成最长的回文子串。
在动态规划问题中,我们找到一个符合条件的
j
j
j ,然后就可以通过状态转移方程由
d
p
[
j
]
dp[j]
dp[j] 推导出
d
p
[
i
]
dp[i]
dp[i] 。
然后,我理一下本题的解法。
当已知一个序列是回文时,在其首尾添加元素后的序列存在两种情况:
- 首尾元素相等,则最长回文的长度 + 2;
- 首尾元素不相等,则最长回文序列长度为 仅添加首元素时的最长回文长度 与 仅添加尾元素时的最长回文长度 的最大值。
状态定义:
d
p
[
i
]
[
j
]
dp[i][j]
dp[i][j] 表示
s
[
i
…
j
]
s[i…j]
s[i…j] 中的最长回文序列长度。
状态转移方程:
- i
>
j
i > j
i>j,
d
p
[
i
]
[
j
]
=
0
dp[i][j] = 0
dp[i][j]=0;
- i
=
=
j
i == j
i==j,
d
p
[
i
]
[
j
]
=
1
dp[i][j] = 1
dp[i][j]=1;
- i
<
j
i < j
i<j 且
s
[
i
]
=
=
s
[
j
]
s[i] == s[j]
s[i]==s[j],
d
p
[
i
]
[
j
]
=
d
p
[
i
+
1
]
[
j
−
1
]
+
2
dp[i][j] = dp[i + 1][j - 1] + 2
dp[i][j]=dp[i+1][j−1]+2;
- i
<
j
i < j
i<j 且
s
[
i
]
!
=
s
[
j
]
s[i]!= s[j]
s[i]!=s[j],
d
p
[
i
]
[
j
]
=
m
a
x
(
d
p
[
i
+
1
]
[
j
]
,
d
p
[
i
]
[
j
−
1
]
)
dp[i][j] = max(dp[i + 1][j],dp[i][j - 1])
dp[i][j]=max(dp[i+1][j],dp[i][j−1]);
遍历顺序:
从状态转移方程可以看出,计算
d
p
[
i
]
[
j
]
dp[i][j]
dp[i][j] 时需要用到
d
p
[
i
+
1
]
[
j
−
1
]
dp[i+1][j - 1]
dp[i+1][j−1] 和
d
p
[
i
+
1
]
[
j
]
dp[i + 1][j]
dp[i+1][j],所以对于
i
i
i 的遍历应该从后向前;对于
j
j
j 的遍历应该从前向后。
返回结果:
最后返回
d
p
[
0
]
[
s
.
l
e
n
g
t
h
(
)
−
1
]
dp[0][s.length() - 1]
dp[0][s.length()−1]。
代码
提供了三种语言的代码。
java 代码
class Solution {
public int longestPalindromeSubseq(String s) {
int size = s.length();
int[][] dp = new int[size][size];
for(int i = size - 1; i >= 0; i--){
dp[i][i] = 1;
for(int j = i + 1; j < size; 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][size - 1];
}
}
C++代码:
class Solution {
public:
int longestPalindromeSubseq(string s) {
int size = s.size();
vector<vector<int>> dp(size, vector<int>(size, 0));
for(int i = size - 1; i >= 0; i--){
dp[i][i] = 1;
for(int j = i + 1; j < size; j++){
if(s[i] == s[j]){
dp[i][j] = dp[i + 1][j - 1] + 2;
}else{
dp[i][j] = max(dp[i + 1][j], dp[i][j - 1]);
}
}
}
return dp[0][size - 1];
}
};
python 代码:
class Solution:
def longestPalindromeSubseq(self, s):
n = len(s)
dp = [[0] * n for _ in range(n)]
for i in range(n - 1, -1, -1):
dp[i][i] = 1
for j in range(i + 1, n):
if s[i] == s[j]:
dp[i][j] = dp[i + 1][j - 1] + 2
else:
dp[i][j] = max(dp[i + 1][j], dp[i][j - 1])
return dp[0][n - 1]
- 时间复杂度:
O
(
N
2
)
O(N^2)
O(N2)
- 空间复杂度:
O
(
N
2
)
O(N^2)
O(N2)
刷题心得
子序列的动态规划解法:两重循环。其实就看对于每个
i
i
i,当找到满足题目要求的
j
j
j 的时候,状态转移方程怎么变化。
参考:http://blog.csdn.net/camellhf/article/details/70337501
日期
2018 年 3 月 15 日 --雾霾消散,春光明媚
2021 年 8 月 12 日——对面在装修,很吵
【LeetCode】516. Longest Palindromic Subsequence 最长回文子序列的更多相关文章
- [LeetCode] 516. Longest Palindromic Subsequence 最长回文子序列
Given a string s, find the longest palindromic subsequence's length in s. You may assume that the ma ...
- 516 Longest Palindromic Subsequence 最长回文子序列
给定一个字符串s,找到其中最长的回文子序列.可以假设s的最大长度为1000. 详见:https://leetcode.com/problems/longest-palindromic-subseque ...
- [LeetCode] Longest Palindromic Subsequence 最长回文子序列
Given a string s, find the longest palindromic subsequence's length in s. You may assume that the ma ...
- Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法)
Leetcode 5. Longest Palindromic Substring(最长回文子串, Manacher算法) Given a string s, find the longest pal ...
- [LeetCode] 5. Longest Palindromic Substring 最长回文子串
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
- [leetcode]5. Longest Palindromic Substring最长回文子串
Given a string s, find the longest palindromic substring in s. You may assume that the maximum lengt ...
- LN : leetcode 516 Longest Palindromic Subsequence
lc 516 Longest Palindromic Subsequence 516 Longest Palindromic Subsequence Given a string s, find th ...
- 516. Longest Palindromic Subsequence最长的不连续回文串的长度
[抄题]: Given a string s, find the longest palindromic subsequence's length in s. You may assume that ...
- [leetcode]516. Longest Palindromic Subsequence最大回文子序列
Given a string s, find the longest palindromic subsequence's length in s. You may assume that the ma ...
随机推荐
- Unity——Js和Unity互相调用
Unity项目可以打包成WebGl,打包后的项目文件: Build中是打包后的Js代码: Index.html是web项目的入口,里面可以调整web的自适应,也可以拿去嵌套: TemplateData ...
- 学习 DDD - 通用语言的模式
大家好,我是霸戈,这周学习了一些关于领域驱动设计的知识 ,对比较深刻的地方做了不少笔记,分享给大家. 在日常需求讨论的时候,经常会碰到一个需求会议开了一个多小时还没有达成共识.作为业务方(领域专家)明 ...
- MySQL:事务常用语句
Mysql(版本是8)的事务隔离级别 默认是RR:REPEATABLE-READ:可重复读 查看 当前隔离级别 全局隔离级别 修改 -- 当前修改 -- 设置成可重复读 SET transactio ...
- 巩固javaweb第十四天
巩固内容: 单行文本框: 单行文本框的基本语法格式如下: < input type="text" name="输入信息的字" value=" ...
- SQLyog连接mysql8报2058错误
连接会话时,报如下错误. 通过网上查解决办法,报这个错误的原因是mysql密码加密方法变了 解决办法: 1.先使用mysql -uroot -p输入密码进去mysql 2.ALTER USER 'ro ...
- Spark中的分区方法详解
转自:https://blog.csdn.net/dmy1115143060/article/details/82620715 一.Spark数据分区方式简要 在Spark中,RDD(Resilien ...
- 商业爬虫学习笔记day5
一. 发送post请求 import requests url = "" # 发送post请求 data = { } response = requests.post(url, d ...
- 《C陷阱与缺陷》 第0章导读 第1章词法陷阱
1.= 与==的区别 赋值运算符= 的优先级要小于逻辑运算符== 也就是说,会进行先逻辑上的比较,然后再把比较结果进行赋值,很合理. getc库是什么??? 1.C语言中有单字符 = 也有多字符单元如 ...
- HelloWorldDynamic
package mbeanTest; import java.lang.reflect.Method; import javax.management.Attribute; import javax. ...
- Spring Boot中使用模板引擎Thymeleaf
一.Thymeleaf简介 Thymeleaf[taɪm lif],百里香叶,是一个流行的模板引擎,该模板引擎采用Java语言开发.Java中常见的模板引擎有Velocity.Freemaker.Th ...