首页 > 编程语言 >代码随想录算法训练营第四十六天|leetcode647. 回文子串、leetcode516.最长回文子序列

代码随想录算法训练营第四十六天|leetcode647. 回文子串、leetcode516.最长回文子序列

时间:2024-12-16 14:03:12浏览次数:7  
标签:子串 随想录 len 链接 range 第四十六 dp 回文

1 leetcode647. 回文子串

题目链接:647. 回文子串 - 力扣(LeetCode)

文章链接:代码随想录

视频链接:动态规划,字符串性质决定了DP数组的定义 | LeetCode:647.回文子串哔哩哔哩bilibili

思路:嘿,看不懂有一点,看解析吧

1.1 视频后的方法

其实看完视频以后,感觉这个题目真的不难,我想到了二维数组,但是我没想到怎么遍历,遍历顺序那里卡了一下

class Solution:
    def countSubstrings(self, s: str) -> int:
        dp = [[False]*len(s) for _ in range(len(s))]
        result = 0
        for i in range(len(s)-1,-1,-1):
            for j in range(i,len(s)):
                if s[i]==s[j]:
                    if j-i<=1:
                        result +=1
                        dp[i][j] = True
                    elif dp[i+1][j-1]:
                        dp[i][j] = True
                        result +=1
        return result
1.2 本题小结
  1. 真的,我想不到这种方法,就是现在还是自己多积累吧,我没办法自己好好写吧

  2. 感觉其实还是挺难的,就是自己做的不好吧

2 leetcode516.最长回文子序列

题目链接:647. 回文子串 - 力扣(LeetCode)

文章链接:代码随想录

视频链接:动态规划再显神通,LeetCode:516.最长回文子序列哔哩哔哩bilibili

思路:其实自己还是不会写的一道题目,慢慢看别人的解析,看明白的

2.1 视频后的思路

就是说,感觉好简单,但是我自己思考不出来

class Solution:
    def longestPalindromeSubseq(self, s: str) -> int:
        dp = [[0]*len(s) for _ in range(len(s))]
        for i in range(len(s)):
            dp[i][i] = 1
        for i in range(len(s)-1,-1,-1):
            for j in range(i+1,len(s)):
                if s[i]==s[j]:
                    dp[i][j] = dp[i+1][j-1]+2
                else:
                    dp[i][j] = max(dp[i][j-1],dp[i+1][j])
        return dp[0][-1]
2.2 本题小结
  1. 动态规划的题目,就是分情况去讨论,然后再去下笔写,不要乱来,这是我发现的一点小规律吧

  2. 动归五部曲在什么时候,其实都是非常适用的一种方法

3 今日小结

  1. 终于把动态规划的题目补完啦,继续开启下一篇张的内容

  2. 动态规划的五部曲我是掌握了,但是对于里面的很多细节,还是需要更多的时间精力去考虑完成的

  3. 终于我又完成了一个版块

标签:子串,随想录,len,链接,range,第四十六,dp,回文
From: https://blog.csdn.net/angela3264/article/details/144385254

相关文章

  • 代码随想录算法训练营第四十五天|leetcode115.不同的子序列、leetcode583. 两个字符串
    1leetcode115.不同的子序列题目链接:115.不同的子序列-力扣(LeetCode)文章链接:代码随想录视频链接:动态规划之子序列,为了编辑距离做铺垫|LeetCode:115.不同的子序列哔哩哔哩bilibili思路:确实看不懂题目,还是看解析吧1.1视频后的方法有一种我看了视频,也没有那么理解是为......
  • 代码随想录算法训练营第四十四天|leetcode1143.最长公共子序列、leetcode1035.不相交
    1leetcode1143.最长公共子序列题目链接:1143.最长公共子序列-力扣(LeetCode)文章链接:代码随想录视频链接:动态规划子序列问题经典题目|LeetCode:1143.最长公共子序列哔哩哔哩bilibili思路:其实我比较清楚的是和上面一道题目的思路,差不太多,但是我不知道非连续的位置应该如何......
  • 题海拾贝:LCR018.验证回文串
               Hello大家好!很高兴我们又见面啦!给生活添点passion,开始今天的编程之路!我的博客:<但凡.我的专栏:《编程之路》、《数据结构与算法之美》、《题海拾贝》欢迎点赞,关注!1、题目2、2、题解         这个题如果没有空格和符号的话,那就直接双指......
  • 【力扣算法】234.回文链表
    快慢指针:一个指针走两步,一个指针走一步,当快指针走到链表末尾时,慢指针走到中间位置。 逆转链表:根据指针位置分成两个表,逆转第二个表。按序判断就可以,如果是相同就是回文,反之就不是。快慢指针能找链表中间,也可以判断链表是否有环/***Definitionforsingly-linkedlist.......
  • 代码随想录day18 | leetcode 530.二叉搜索树的最小绝对差 501.二叉搜索树中的众数 236
    刷题收获所有递归的写法都与正常人类想法的实现顺序相反,都是先写条件成立会发生什么再写递归成立条件通过递归调用栈实现回到上一个节点节点(恢复上一层的状态),调用栈能够记录每次递归调用的函数状态,包括函数的局部变量、参数以及函数执行到的具体位置。当递归到某个节点......
  • 代码随想录训练营第十五天| 110.平衡二叉树 257. 二叉树的所有路径 404.左叶子之和 22
    110.平衡二叉树题目链接:110.平衡二叉树-力扣(LeetCode)讲解链接:代码随想录 求高度不是求深度高度需要从下到上(后序遍历)深度需要从上到下(先序遍历)Java代码:classSolution{publicbooleanisBalanced(TreeNoderoot){//递归做法returngetHeight......
  • 代码随想录训练营第十八天| 530.二叉搜索树的最小绝对差 501.二叉搜索树中的众数 236.
     530.二叉搜索树的最小绝对差 题目链接/文章讲解:代码随想录视频讲解:二叉搜索树中,需要掌握如何双指针遍历!|LeetCode:530.二叉搜索树的最小绝对差_哔哩哔哩_bilibili 注意是二叉搜索树,二叉搜索树可是有序的。给你一个二叉搜索树的根节点 root ,返回 树中任意两......
  • leetcode 866. 回文质数
    866.回文质数想着开大数组,用质数筛选的方法。但是开大数组超内存了......
  • 代码随想录算法训练营第四十六天|LeetCode647.回文串、LeetCode516.最长回文子序列
    前言打卡代码随想录算法训练营第49期第四十六天 ε(*′・∀・`)з゙首先十分推荐学算法的同学可以先了解一下代码随想录,可以在B站卡哥B站账号、代码随想录官方网站代码随想录了解,卡哥清晰易懂的算法教学让我直接果断关注,也十分有缘和第49期的训练营大家庭一起进步。LeetCode647......
  • 代码随想录算法训练营第四十五天|LeetCode115.不同的子序列、LeetCode583.两个字符串
    前言打卡代码随想录算法训练营第49期第四十五天ε(*′・∀・`)з゙首先十分推荐学算法的同学可以先了解一下代码随想录,可以在B站卡哥B站账号、代码随想录官方网站代码随想录了解,卡哥清晰易懂的算法教学让我直接果断关注,也十分有缘和第49期的训练营大家庭一起进步。LeetCode115不......