代码随想录算法训练营第三十九天|115.不同的子序列、583. 两个字符串的删除操作

代码随想录算法训练营第三十九天

115.不同的子序列

文章讲解

复制代码
class Solution {
public:
    int numDistinct(string s, string t) {
        vector<vector<uint64_t>> dp(s.size() + 1, vector<uint64_t>(t.size() + 1));
        for (int i = 0; i < s.size(); i++) dp[i][0] = 1;
        for (int j = 1; j < t.size(); j++) dp[0][j] = 0;
        for (int i = 1; i <= s.size(); i++) {
            for (int j = 1; j <= t.size(); 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.size()][t.size()];
    }
};

583. 两个字符串的删除操作

文章讲解

复制代码
class Solution {
public:
    int minDistance(string word1, string word2) {
        vector<vector<int>> dp(word1.size() + 1, vector<int>(word2.size() + 1));
        for (int i = 0; i <= word1.size(); i++) dp[i][0] = i;
        for (int j = 0; j <= word2.size(); j++) dp[0][j] = j;
        for (int i = 1; i <= word1.size(); i++) {
            for (int j = 1; j <= word2.size(); j++) {
                if (word1[i - 1] == word2[j - 1]) {
                    dp[i][j] = dp[i - 1][j - 1];
                } else {
                    dp[i][j] = min(dp[i - 1][j] + 1, dp[i][j - 1] + 1);
                }
            }
        }
        return dp[word1.size()][word2.size()];
    }
};
相关推荐
小郭团队6 分钟前
1_1_七段式SVPWM (传统算法反正切)算法理论与 MATLAB 实现详解
人工智能·stm32·嵌入式硬件·算法·dsp开发
翟天保Steven11 分钟前
医学影像-CBCT图像重建FDK算法
算法·医学影像·图像重建
星诺算法备案13 分钟前
《算法安全自评估报告》的填报与实操(附模板)
人工智能·算法·备案·算法备案
AAD5558889920 分钟前
自动驾驶环境中的车辆目标检测——基于YOLO11-C3k2-RVB的改进算法
算法·目标检测·自动驾驶
洛生&22 分钟前
Flight Discount
算法
郝学胜-神的一滴28 分钟前
Python类属性与实例属性详解及MRO算法演进
开发语言·python·程序人生·算法
sonadorje39 分钟前
支持向量机 (SVM) 通俗解读
算法·机器学习·支持向量机
Dylan的码园43 分钟前
深入浅出Java排序:从基础算法到实战优化(上)
java·数据结构·算法
星火开发设计44 分钟前
从公式到应用:卷积公式全面解析与实战指南
学习·算法·机器学习·概率论·知识·期末考试·卷积公式