LeetCode 516*. 最长回文子序列(Python)

简介: 给定一个字符串s,找到其中最长的回文子序列。可以假设s的最大长度为1000。

给定一个字符串s,找到其中最长的回文子序列。可以假设s的最大长度为1000。


示例 1:


输入:

"bbbab"

输出:

4


一个可能的最长回文子序列为 "bbbb"。


示例 2:


输入:

"cbbd"

输出:

2


一个可能的最长回文子序列为 "bb"。



思路:


仍然是动态规划。将字符串横竖列开,变成一个二维数组f,f[ i ][ j ]表示 s 的第 i 个字符到第 j 个字符组成的子串中,最长的回文序列长度是多少。


初始状态:对角线字符都是回文,记为 1。


如果 s 的第 i 个字符和第 j 个字符相同:


f[ i ][ j ] = f[i + 1][j - 1] + 2


如果 s 的第 i 个字符和第 j 个字符不同:


f[ i ][ j ] = max(f[i + 1][ j ], f[ i ][j - 1])


然后注意遍历顺序,i 从最后一个字符开始往前遍历,j 从 i + 1 开始往后遍历,保证每个子问题都已经算好了。


最终返回f[0][n - 1]即可。


class Solution(object):
    def longestPalindromeSubseq(self, s):
        """
        :type s: str
        :rtype: int
        """
        length = len(s)
        f = [[0 for i in range(length)] for j in range(length)] 
        for i in range(length-1, -1, -1):
            f[i][i] = 1
            for j in range(i+1, length):
                if s[i] == s[j]:
                    f[i][j] = f[i+1][j-1] + 2
                else:
                    f[i][j] = max(f[i+1][j], f[i][j-1])
        return f[0][length-1]




相关文章
|
1天前
|
机器学习/深度学习 运维 Python
python深度学习实现自编码器Autoencoder神经网络异常检测心电图ECG时间序列
python深度学习实现自编码器Autoencoder神经网络异常检测心电图ECG时间序列
|
1天前
|
数据可视化 数据挖掘 Python
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化(下)
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化
|
1天前
|
数据可视化 API 开发者
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化(上)
Python时间序列分析苹果股票数据:分解、平稳性检验、滤波器、滑动窗口平滑、移动平均、可视化
|
1天前
|
索引 Python
【Python操作基础】——序列
【Python操作基础】——序列
|
1天前
leetcode代码记录(最长连续递增序列
leetcode代码记录(最长连续递增序列
12 2
|
1天前
leetcode代码记录(最长递增子序列
leetcode代码记录(最长递增子序列
9 1
|
1天前
|
算法
leetcode代码记录(摆动序列
leetcode代码记录(摆动序列
9 0
|
1天前
|
数据采集 数据挖掘 测试技术
python、R语言ARIMA-GARCH分析南方恒生中国企业ETF基金净值时间序列分析
python、R语言ARIMA-GARCH分析南方恒生中国企业ETF基金净值时间序列分析
|
1天前
|
vr&ar Python
Python自激励阈值自回归(SETAR)、ARMA、BDS检验、预测分析太阳黑子时间序列数据
Python自激励阈值自回归(SETAR)、ARMA、BDS检验、预测分析太阳黑子时间序列数据
|
1天前
|
Python
Python随机波动性SV模型:贝叶斯推断马尔可夫链蒙特卡洛MCMC分析英镑/美元汇率时间序列数据|数据分享
Python随机波动性SV模型:贝叶斯推断马尔可夫链蒙特卡洛MCMC分析英镑/美元汇率时间序列数据|数据分享