zoukankan      html  css  js  c++  java
  • 0516最长回文子序列 Marathon

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

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

    示例 1:

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

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

    提示:

    1 <= s.length <= 1000
    s 仅由小写英文字母组成

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/longest-palindromic-subsequence

    参考:

    python

    # 0516.最长回文子串
    
    class Solution:
        def longestPalindromicSubSeq(self, s: str) -> int:
            """
            动态规划,回文串
            1.dp
            - dp[i][j]:字符串s在[i, j]范围内最长的回文子序列的长度为dp[i][j]
            2.递推
            - s[i] == s[j], dp[i][j] = dp[i+1][j-1] + 2
            - s[i] != s[j] , dp[i][j] = max(dp[i + 1][j], dp[i][j - 1])
            3.初始化
            - dp[i][i] = 1
            4.遍历顺序
            - 外层后向前
            - 前到后
    
            :param s:
            :return:
            """
            dp = [[0] * len(s) for _ in range(len(s))]
            for i in range(len(s)):
                dp[i][i] = 1
            for i in range(len(s)-1, -1, -1):
                for j in range(i+1, len(s)):
                    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][-1]
    

    golang

    package dynamicPrograming
    
    // 动态规划
    func longestPalindromicSubseq(s string) int {
    	length := len(s)
    	dp := make([][]int, length)
    	// 初始化
    	for i:=0;i<length;i++ {
    		for j:=0;j<length;j++ {
    			if dp[i] == nil {
    				dp[i] = make([]int, length)
    			}
    			if i==j {
    				dp[i][j] = 1
    			}
    		}
    	}
    	// 遍历
    	for i:=length-1;i>=0;i-- {
    		for j:=i+1;j<length;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][length-1]
    }
    
    func max(a,b int) int {
    	if a < b {return b}
    	return a
    }
    
    
  • 相关阅读:
    接口的幂等性原则
    SpringBoot热部署-解决方案
    @Resource 与 @Service注解的区别
    软件概要设计做什么,怎么做
    First Show
    Glide源码解析一,初始化
    android使用giflib加载gif
    android的APT技术
    RxJava的concat操作符
    RxJava基本使用
  • 原文地址:https://www.cnblogs.com/davis12/p/15647216.html
Copyright © 2011-2022 走看看