【代码随想录训练营】【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]
                
        
相关推荐
黛色正浓7 分钟前
leetCode-热题100-贪心合集(JavaScript)
javascript·算法·leetcode
轻微的风格艾丝凡26 分钟前
嵌入式定时器计时技巧:用有符号数省略溢出判断的底层逻辑与实践
数据库·算法·dsp开发·嵌入式软件
No0d1es32 分钟前
2025年12月 GESP CCF编程能力等级认证C++四级真题
算法·青少年编程·等级考试·gesp·ccf
CodeByV1 小时前
【算法题】快排
算法
一起努力啊~1 小时前
算法刷题--长度最小的子数组
开发语言·数据结构·算法·leetcode
rchmin1 小时前
限流算法:令牌桶与漏桶详解
算法·限流
leoufung1 小时前
LeetCode 221:Maximal Square 动态规划详解
算法·leetcode·动态规划
黑符石1 小时前
【论文研读】Madgwick 姿态滤波算法报告总结
人工智能·算法·机器学习·imu·惯性动捕·madgwick·姿态滤波
源代码•宸1 小时前
Leetcode—39. 组合总和【中等】
经验分享·算法·leetcode·golang·sort·slices
好易学·数据结构1 小时前
可视化图解算法77:零钱兑换(兑换零钱)
数据结构·算法·leetcode·动态规划·力扣·牛客网