代码随想录算法训练营第四十九天|leetcode516、647题

1、leetcode第647题

本题要求找字符串中回文子串的数目,因此设置dp数组,dp[i][j]的含义是从下标i到j的子串是不是回文串,因此递推公式为:在s[i]=s[j]时如果间距小于等于1或者间距大于1时dp[i+1][j-1]为回文串则dp[i][j]也为回文串。dp数组为bool数组,dp数组初始化为false,最后统计为true的元素数即为最后的回文子串数。

具体代码如下:

cpp 复制代码
class Solution {
public:
    int countSubstrings(string s) {
    vector<vector<bool>>dp(s.length(),vector<bool>(s.length(),false));
    int result =0;
    for(int i=s.length()-1;i>=0;i--)
    {
        for(int j=i;j<s.length();j++)
        {
            if(s[i]==s[j])
            {
                if(j-i<=1)
                {
                    dp[i][j]=true;
                    result++;
                }
                else if(j-i>1&&dp[i+1][j-1]==true)
                {
                    dp[i][j]=true;
                    result++;
                }
            }
        }
    }
    return result;
    }
};

二、leetcode第516题

本题要求最长回文子串的长度,设置dp数组,dp[i][j]的含义是下标为i到j的子串中最长回文子串的长度,递推公式为:s[i]=s[j]时,dp[i][j]=dp[i-1][j-1]+2,不等时,dp[i][j]=max(dp[i-1][j],dp[i][j-1])。

初始化时均设置为0,将dp[i][i]初始化为1。

具体代码如下:

cpp 复制代码
class Solution {
public:
    int longestPalindromeSubseq(string s) {
    vector<vector<int>>dp(s.length(),vector<int>(s.length(),0));
    for(int i=0;i<s.length();i++)
    {
        dp[i][i]=1;
    }
    for(int i=s.length()-1;i>=0;i--)
    {
        for(int j=i+1;j<s.length();j++)
        {
            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][s.length()-1];
    }
};
相关推荐
空白到白10 分钟前
决策树-面试题
算法·决策树·机器学习
flashlight_hi11 分钟前
LeetCode 分类刷题:2563. 统计公平数对的数目
python·算法·leetcode
前端世界27 分钟前
HarmonyOS 数据处理性能优化:算法 + 异步 + 分布式实战
算法·性能优化·harmonyos
楼田莉子30 分钟前
C++算法专题学习:栈相关的算法
开发语言·c++·算法·leetcode
kyle~1 小时前
排序---冒泡排序(Bubble Sort)
c语言·c++·算法
l1t1 小时前
我改写的二分法XML转CSV文件程序速度追上了张泽鹏先生的
xml·c语言·人工智能·算法·expat
一碗白开水一1 小时前
【论文阅读】Far3D: Expanding the Horizon for Surround-view 3D Object Detection
论文阅读·人工智能·深度学习·算法·目标检测·计算机视觉·3d
轮到我狗叫了1 小时前
力扣.1054距离相等的条形码力扣767.重构字符串力扣47.全排列II力扣980.不同路径III力扣509.斐波那契数列(记忆化搜索)
java·算法·leetcode
久菜盒子工作室2 小时前
量化金融|基于算法和模型的预测研究综述
算法·金融
CoovallyAIHub2 小时前
SBP-YOLO:面向嵌入式悬架的轻量实时模型,实现减速带与坑洼高精度检测
深度学习·算法·计算机视觉