代码随想录算法训练营第三十九天|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()];
    }
};
相关推荐
WG_171 小时前
图的储存+图的遍历
数据结构·算法
C-DHEnry1 小时前
SPFA+SPFA优化+优先队列(汽车加油行驶问题_铺垫aa、汽车加油行驶问题qiche、EasySSSPsssp)
算法·汽车
疾跑哥布林升级版1 小时前
C++---day7
开发语言·c++·算法
MPCTHU1 小时前
线性方程组的解法
数据结构·算法
人类群星闪耀时1 小时前
跳跃游戏的最优解法——贪心算法的智慧与实践
算法·游戏·贪心算法
麦城稻香咖啡1 小时前
Day51 | 3. 无重复字符的最长子串、12. 整数转罗马数字、49. 字母异位词分组、73. 矩阵置零
算法
梭七y2 小时前
【力扣hot100题】(071)每日温度
算法·leetcode·职场和发展
Allen Wurlitzer2 小时前
算法刷题记录——LeetCode篇(2.4) [第131~140题](持续更新)
算法·leetcode·职场和发展
ylfhpy2 小时前
Java面试黄金宝典35
java·数据库·sql·算法·面试·职场和发展
奋进的小暄2 小时前
贪心算法(16)(java)俄罗斯套娃信封问题
算法·贪心算法