【代码随想录训练营】【Day 60】【动态规划-13】| Leetcode 647, 516

【代码随想录训练营】【Day 60】【动态规划-13】| Leetcode 647, 516

需强化知识点

  • 动态规划-回文系列

题目

647. 回文子串

  • 注意sum(dp)不行
  • j的遍历要倒序,并且 for j in range(i, n):
python 复制代码
class Solution:
    def countSubstrings(self, s: str) -> int:
        n = len(s)
        dp = [[0]*(n) for _ in range(n)]
        result = 0

        for i in range(n-1, -1, -1):
            for j in range(i, n):
                if s[i] == s[j]:
                    if j - i == 0:
                        dp[i][j] = 1
                        result += 1
                    elif abs(j - i) ==  1:
                        dp[i][j] = 1
                        result += 1
                    else:
                        dp[i][j] = dp[i+1][j-1]
                        if dp[i+1][j-1]:
                            result += 1
                else:
                    dp[i][j] = 0
        
        return sum([sum(sublist) for sublist in dp])

516. 最长回文子序列

  • 注意 python int max为 2**31 -1
  • 滑动窗口,固定结束位置的方式,然后注意nums包含0,所以while判断是>=
python 复制代码
class Solution:
    def longestPalindromeSubseq(self, s: str) -> int:
        n = len(s)
        # 以 i,j 的 最长序列长度
        dp  = [[0] * (n) for _ in range(n)]
        for i in range(n):
            dp[i][i] = 1

        for i in range(n-1, -1, -1):
            for j in range(i+1, n):
                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][n-1]
                
        
相关推荐
Greedy Alg3 小时前
LeetCode 142. 环形链表 II
算法
睡不醒的kun3 小时前
leetcode算法刷题的第三十二天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
先做个垃圾出来………3 小时前
残差连接的概念与作用
人工智能·算法·机器学习·语言模型·自然语言处理
SuperCandyXu5 小时前
P3205 [HNOI2010] 合唱队-普及+/提高
c++·算法·洛谷
_OP_CHEN5 小时前
数据结构(C语言篇):(十二)实现顺序结构二叉树——堆
c语言·数据结构·算法·二叉树·学习笔记··顺序结构二叉树
Yingjun Mo5 小时前
1. 统计推断-基于神经网络与Langevin扩散的自适应潜变量建模与优化
人工智能·神经网络·算法·机器学习·概率论
地平线开发者6 小时前
征程 6 | 灰度图部署链路介绍
算法·自动驾驶
地平线开发者6 小时前
手撕大模型|KVCache 原理及代码解析
算法·自动驾驶
共享家95277 小时前
经典动态规划题解
算法·leetcode·动态规划
Pluchon7 小时前
硅基计划3.0 Map类&Set类
java·开发语言·数据结构·算法·哈希算法·散列表