Merge pull request #1336 from Hanmengnan/master

更新0516.最长回文子序列的Go实现提供了一种更优的方法
This commit is contained in:
程序员Carl
2022-06-05 09:34:00 +08:00
committed by GitHub

View File

@ -186,29 +186,28 @@ class Solution:
Go Go
```Go ```Go
func longestPalindromeSubseq(s string) int { func longestPalindromeSubseq(s string) int {
lenth:=len(s) size := len(s)
dp:=make([][]int,lenth) max := func(a, b int) int {
for i:=0;i<lenth;i++{ if a > b {
for j:=0;j<lenth;j++{ return a
if dp[i]==nil{
dp[i]=make([]int,lenth)
} }
if i==j{ return b
dp[i][j]=1
} }
dp := make([][]int, size)
for i := 0; i < size; i++ {
dp[i] = make([]int, size)
dp[i][i] = 1
} }
} for i := size - 1; i >= 0; i-- {
for i:=lenth-1;i>=0;i--{ for j := i + 1; j < size; j++ {
for j:=i+1;j<lenth;j++{
if s[i] == s[j] { if s[i] == s[j] {
dp[i][j] = dp[i+1][j-1] + 2 dp[i][j] = dp[i+1][j-1] + 2
} else { } else {
dp[i][j]=max(dp[i+1][j],dp[i][j-1]) dp[i][j] = max(dp[i][j-1], dp[i+1][j])
} }
} }
} }
return dp[0][size-1]
return dp[0][lenth-1]
} }
``` ```