代码随想录训练营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; 
    }
};
相关推荐
Struggle_97554 小时前
算法知识-背包dp
算法
ZPC82104 小时前
Linux 共享内存(shm)
算法
水木流年追梦4 小时前
大模型入门-应用篇2-RAG (检索增强生成):从原理到 Python 实战
开发语言·python·算法·prompt
数智工坊4 小时前
【连续动作空间算法2】TD3:DDPG的终极进化,根治连续控制中的函数近似误差
论文阅读·人工智能·算法·计算机视觉
洛水水5 小时前
【力扣100题】25. 搜索二维矩阵 II
算法·leetcode·矩阵
样例过了就是过了5 小时前
LeetCode热题100 多数元素
c++·算法·leetcode·贪心算法
白羊by5 小时前
YOLOv8 官方损失函数详解(按任务分类)
人工智能·深度学习·算法·yolo·分类
沪漂阿龙5 小时前
面试题:逻辑回归是什么?为什么用 Sigmoid、对数损失、最大似然、Softmax、多分类、类别不平衡一文讲透
人工智能·算法·机器学习·分类·逻辑回归
酿情师5 小时前
区块链原理与技术02:UTXO 模型、账户余额模型与以太坊账户体系(区块链的数据结构03)
数据结构·区块链
WL_Aurora5 小时前
备战蓝桥杯国赛【Day 9】
python·算法·蓝桥杯