zoukankan      html  css  js  c++  java
  • 2021-02-08:给定一个字符串str,请问这个字符串的最长回文子序列长度是多少?

    2021-02-08:给定一个字符串str,请问这个字符串的最长回文子序列长度是多少?

    福哥答案2021-02-08:

    自然智慧即可。
    1.原序列和反序列求公共子序列。无代码。
    2.递归。有代码。
    3.动态规划。有代码。
    根据动态规划表,dp[i][j]取【左边】,【下边】,【左下边】或者【左下边+2】)的最大值。
    【左下边】还是【左下边+2】?i==j,取【左下边+2】;i!=j,取【左下边】。

    代码用golang编写,代码如下:

    package main
    
    import "fmt"
    
    func main() {
        ret := longestPalindromeSubseq("bbbabbbb")
        fmt.Println("递归:", ret)
        ret = longestPalindromeSubseq2("bbbabbbb")
        fmt.Println("动态规划:", ret)
    }
    
    //递归
    func longestPalindromeSubseq(s string) int {
        return process(s)
    }
    func process(s string) int {
        sLen := len(s)
        if sLen == 0 {
            return 0
        }
        if sLen == 1 {
            return 1
        }
        ret1 := process(s[1 : sLen-1])
        ret2 := 0
        ret3 := 0
        if s[0] != s[sLen-1] {
            ret2 = process(s[0 : sLen-1])
            ret3 = process(s[1:sLen])
        } else {
            ret1 += 2
        }
        ret := getMax(ret1, ret2)
        ret = getMax(ret, ret3)
        return ret
    }
    
    //动态规划
    func longestPalindromeSubseq2(s string) int {
        sLen := len(s)
        if sLen == 0 {
            return 0
        }
        if sLen == 1 {
            return 1
        }
        dp := make([][]int, sLen)
        for i := 0; i < sLen; i++ {
            dp[i] = make([]int, sLen)
        }
        for i := 0; i < sLen-1; i++ {
            dp[i][i] = 1
            if s[i] == s[i+1] {
                dp[i][i+1] = 2
            } else {
                dp[i][i+1] = 1
            }
        }
        for L := sLen - 3; L >= 0; L-- {
            for R := L + 2; R < sLen; R++ {
                dp[L][R] = getMax(dp[L][R-1], dp[L+1][R])
                if s[L] == s[R] {
                    dp[L][R] = getMax(dp[L][R], 2+dp[L+1][R-1])
                }
            }
        }
        return dp[0][sLen-1]
    }
    
    func getMax(a int, b int) int {
        if a > b {
            return a
        } else {
            return b
        }
    }
    

      

    执行结果如下:

    ***
    [左神java代码](https://github.com/algorithmzuo/algorithmbasic2020/blob/master/src/class20/Code01_PalindromeSubsequence.java)
    [力扣516](https://leetcode-cn.com/problems/longest-palindromic-subsequence/)
    [评论](https://user.qzone.qq.com/3182319461/blog/1612741776)

  • 相关阅读:
    shell 编写简单的整数计算器
    信号控制
    MySQL-索引及优化整理
    Java面试-Java容器有哪些
    C语言宏定义
    值类型与引用类型的区别
    C++虚函数简介
    DNS-域名解析
    扇区,簇,块区分
    Java合并两个数组为一个新数组
  • 原文地址:https://www.cnblogs.com/waitmoon/p/14391339.html
Copyright © 2011-2022 走看看