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

1、leetcode第647题

本题要求找字符串中回文子串的数目,因此设置dp数组,dpij的含义是从下标i到j的子串是不是回文串,因此递推公式为:在si=sj时如果间距小于等于1或者间距大于1时dpi+1j-1为回文串则dpij也为回文串。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数组,dpij的含义是下标为i到j的子串中最长回文子串的长度,递推公式为:si=sj时,dpij=dpi-1j-1+2,不等时,dpij=max(dpi-1j,dpij-1)。

初始化时均设置为0,将dpii初始化为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];
    }
};
相关推荐
我材不敲代码2 小时前
Python基础: 函数超全详解:定义、参数、返回值、作用域与递归
开发语言·python·算法
罗超驿2 小时前
11.LeetCode 1004. 最大连续1的个数 III | 滑动窗口解法详解(Java)
java·算法·leetcode
QiLinkOS2 小时前
发明人与专利价值共生逻辑
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法
计算机安禾2 小时前
【算法分析与设计】第21篇:回溯法的状态空间树与剪枝函数设计
大数据·人工智能·算法·机器学习·数据挖掘·剪枝
磊 子2 小时前
STL之set以及set和map区别
开发语言·c++·算法
Promise微笑2 小时前
算法突围:“双核四驱”理论下的“官网”AI引用概率提升指南
人工智能·算法·chatgpt
KaMeidebaby2 小时前
卡梅德生物技术快报|免疫共沉淀 - Co-IP 实验在转录因子 ATF3/Smad4 蛋白互作研究中的应用实例解析
网络·人工智能·网络协议·tcp/ip·其他·算法·新浪微博
wayz112 小时前
20260530 软件ETF(159852)量化分析
算法·金融·数据分析·量化交易
通信小呆呆3 小时前
Hankel结构及其快速算法详解
线性代数·算法·机器学习
四代水门3 小时前
服务端倒带(Server-Side Rewind)命中判定系统
java·前端·算法