码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【Leetcode刷题Python】516. 最长回文子序列


    1 题目

    给你一个字符串 s ,找出其中最长的回文子序列,并返回该序列的长度。

    子序列定义为:不改变剩余字符顺序的情况下,删除某些字符或者不删除任何字符形成的一个序列。

    示例 1:

    输入:s = “bbbab”
    输出:4
    解释:一个可能的最长回文子序列为 “bbbb” 。

    示例 2:

    输入:s = “cbbd”
    输出:2
    解释:一个可能的最长回文子序列为 “bb” 。

    2 解析

    和leetcoe 1143题思路一样的,区别在于,只需要将字符串逆转,求最长公共子序列即可。
    求最长公共子序列的思路如下
    在这里插入图片描述
    思路:如果 t e x t 1 [ i ] = = t e x t 2 [ j ] text1[i]==text2[j] text1[i]==text2[j],则在矩阵中是从左上角往右下角沿着对角线移动,如果不等于,即i+1或者j+1的情况时,在矩阵中是右移和下移。所以状态转移是,两种情况,第一种,相等,则dp+1,向右下角移动,不相等,取前上面和左边的dp中最大值。

    状态: dp[i][j]表示i行j列的矩阵中,最长的公共子数组

    状态转移:
    dp [ i ] [ j ] = { dp [ i − 1 ] [ j − 1 ] + 1 , text 1 [ i − 1 ] = text 2 [ j − 1 ] max ⁡ ( dp [ i − 1 ] [ j ] , dp [ i ] [ j − 1 ] ) , text 1 [ i − 1 ] ≠ text 2 [ j − 1 ] \textit{dp}[i][j] =

    {dp[i−1][j−1]+1,text1[i−1]=text2[j−1]max(dp[i−1][j],dp[i][j−1]),text1[i−1]≠text2[j−1]" role="presentation" style="position: relative;">{dp[i−1][j−1]+1,max(dp[i−1][j],dp[i][j−1]),text1[i−1]=text2[j−1]text1[i−1]≠text2[j−1]{dp[i−1][j−1]+1,text1[i−1]=text2[j−1]max(dp[i−1][j],dp[i][j−1]),text1[i−1]≠text2[j−1]
    dp[i][j]={dp[i−1][j−1]+1,max(dp[i−1][j],dp[i][j−1]),​text1​[i−1]=text2​[j−1]text1​[i−1]=text2​[j−1]​

    最终计算得到dp[m][n] 即为text1和text2的最长公共子序列的长度。

    3 python实现

    class Solution:
        def longestPalindromeSubseq(self, s: str) -> int:
            s2 = s[::-1]
            n = len(s)
            dp = [[0]*(n+1) for _ in range(n+1)]
            for i in range(1,n+1):
                for j in range(1,n+1):
                    if s[i-1]==s2[j-1]:
                        dp[i][j] = dp[i-1][j-1]+1
                    else:
                        dp[i][j] = max(dp[i-1][j],dp[i][j-1])
            return dp[n][n]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
  • 相关阅读:
    辉芒微IO单片机FT60F210-URT
    --initialize specified but the data directory has files in it. Aborting. 问题解决
    部署elasticsearch集群
    猴子也能学会的jQuery第七期——jQuery动画(上)
    【k8s】1、基础概念和架构及组件
    【日常计算机问题】win11、win10解决公共WiFi认证不弹出的问题。电脑没有弹出认证界面。以广州图书馆i-guangdong;i广东为例
    SPDX规范详解
    mysql驱动包引起的告警问题using SSL the verifyServerCertificate property is set to ‘false‘
    关于web自动化元素定位,你想知道的都在这里
    C++语言之虚函数、多态、抽象类
  • 原文地址:https://blog.csdn.net/weixin_43935696/article/details/126794674
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号