代码随想录算法训练营第四十七天|leetcode115、392题

一、leetcode第392题

本题要求判断s是否为t的子序列,因此设置dp数组,dp[i][j]的含义是下标为i-1的子串与下标为j-1的子串相同字符的个数,可得递推公式是通过s[i-1]和t[j-1]是否相等区分。

具体代码如下:

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

二、leetcode第115题

本题要求s的子串与t相等的个数,因此设置dp数组,其中dp[i][j]的含义是i-1为下标的子串中包含j-1为下标的子串的个数,根据s[i-1]和t[j-1]是否相等来写递推公式,相等时递推公式dp[i][j]由dp[i-1][j-1](考虑s[i-1])和dp[i-1][j](不考虑s[i-1])构成,不相等时则等于不考虑s[i-1]时的递推式。

具体代码如下:

cpp 复制代码
class Solution {
public:
    int numDistinct(string s, string t) {
    vector<vector<uint64_t>>dp(s.length()+1,vector<uint64_t>(t.length()+1));
    for(int i=0;i<=s.length();i++)
    {
        dp[i][0]=1;
    }
    for(int j=1;j<=t.length();j++)
    {
        dp[0][j]=0;
    }
    for(int i=1;i<=s.length();i++)
    {
        for(int j=1;j<=t.length();j++)
        {
            if(s[i-1]==t[j-1])
            {
                dp[i][j]=dp[i-1][j-1]+dp[i-1][j];
            }
            else
            {
                dp[i][j]=dp[i-1][j];
            }
        }
    }
    return dp[s.length()][t.length()];
    }
};
相关推荐
博笙困了1 分钟前
AcWing学习——差分
c++·算法
NAGNIP5 分钟前
认识 Unsloth 框架:大模型高效微调的利器
算法
NAGNIP5 分钟前
大模型微调框架之LLaMA Factory
算法
echoarts6 分钟前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Python技术极客11 分钟前
一款超好用的 Python 交互式可视化工具,强烈推荐~
算法
徐小夕15 分钟前
花了一天时间,开源了一套精美且支持复杂操作的表格编辑器tablejs
前端·算法·github
小刘鸭地下城28 分钟前
深入浅出链表:从基础概念到核心操作全面解析
算法
小刘鸭地下城38 分钟前
哈希表核心精要:从 O(1) 原理到链式地址与开放寻址
算法
BenChuat1 小时前
Java常见排序算法实现
java·算法·排序算法
元亓亓亓1 小时前
LeetCode热题100--105. 从前序与中序遍历序列构造二叉树--中等
算法·leetcode·职场和发展