代码随想录训练营Day52

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


前言

提示:这里可以添加本文要记录的大概内容:

今天是跟着代码随想录刷题的第52天,主要学习了回文子串和最长回文子序列


提示:以下是本篇文章正文内容,下面案例可供参考

一、回文子串

思路:

这道题dp【i】【j】等于0或者1,如果是0就说明不是回文,如果是1就是回文,核心思路是,如果首和尾相等,这时候需要判断情况,如果首尾相差小于等于2,就做对应的行为,如果大于2,就看中间的是不是也是回文,如果是那么整个就是回文,回文对应的数量要加1,因为最后是求回文的子串一共有多少个。注意要根据dp[i+1][j-1]==1这里能看出来遍历的顺序,i需要从后向前遍历,j需要从前向后遍历。

代码:

cpp 复制代码
class Solution {
public:
    int countSubstrings(string s) {
    vector<vector<int>> dp(s.size(),vector<int>(s.size(),0));
    int huiwen=0;

    for(int i=s.size()-1;i>=0;i--)
    {
        for(int j=i;j<s.size();j++)
        {
            if(s[i]==s[j])
            {
                if(i==j||j==i+1||j==i+2)
                {
                    dp[i][j]=1;
                    huiwen++;
                }
                else 
                {
                    if(dp[i+1][j-1]==1)//从这里可以看出遍历顺序,
                    {
                        dp[i][j]=1;
                        huiwen++;
                    }
                }
            }
        }
    }
    return huiwen;
    }
};

二、最长回文子序列

思路:

这道题的dp【i】【j】是字符串s在i,j范围内最长的回文子序列的长度,这时候同样是分左右相等或者不相等的情况,如果相等,并且首位差大于1的话,就是去掉首尾的最长长度加2(一个首一个尾),主要是这里主要是关注不相等,那么首尾分别缩进一下看哪个更大,dp[i][j]=max(dp[i+1][j],dp[i][j-1])

代码:

cpp 复制代码
class Solution {
public:
    int longestPalindromeSubseq(string s) {
    vector<vector<int>> dp(s.size(),vector<int>(s.size(),0));
    int max1=INT_MIN;
    for(int i=s.size()-1;i>=0;i--)
    {
        for(int j=i;j<s.size();j++)
        {
            if(s[i]==s[j])
            {
                if(j-i<=1)
                {
                    dp[i][j]=j-i+1;    
                }
                else
                {
                    dp[i][j]=dp[i+1][j-1]+2;
                }
                
                
            }
            else
            {
                dp[i][j]=max(dp[i+1][j],dp[i][j-1]);
                
            }
            max1=max(dp[i][j],max1);
        }
    }
    return max1; 
    }
};
相关推荐
祈安_18 分钟前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮14 小时前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
千寻girling20 小时前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
颜酱1 天前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
CoovallyAIHub2 天前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
NineData2 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
木心月转码ing2 天前
Hot100-Day14-T33搜索旋转排序数组
算法
会员源码网2 天前
内存泄漏(如未关闭流、缓存无限增长)
算法
颜酱2 天前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
颜酱2 天前
从0到1实现LRU缓存:思路拆解+代码落地
javascript·后端·算法