【代码随想录训练营】【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]
                
        
相关推荐
Jack203 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树5 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE21221 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21221 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法