力扣第46天--- 第583题、第72题

力扣第45天----第583题、第72题

文章目录

一、第583题--两个字符串的删除操作

c++ 复制代码
class Solution {
public:
    int minDistance(string word1, string word2) {
        vector<vector<int>> dp(word1.size()+1, vector<int>(word2.size()+1, 0));
        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, min(dp[i][j-1]+1, dp[i-1][j-1]+2));
            }
        }
        return dp[word1.size()][word2.size()];
    }
};

二、第72题--编辑距离

​ 很不好想,但是代码跟上一题,差别很小。分为增、删、改3种,增、删的逻辑一致。

c++ 复制代码
class Solution {
public:
    int minDistance(string word1, string word2) {
        vector<vector<int>> dp(word1.size()+1, vector<int>(word2.size()+1, 0));
        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, min(dp[i][j-1]+1, dp[i-1][j-1]+1));
            }
        }
        return dp[word1.size()][word2.size()];
    }
};
相关推荐
普通网友34 分钟前
分布式锁服务实现
开发语言·c++·算法
普通网友36 分钟前
移动语义在容器中的应用
开发语言·c++·算法
Bony-41 分钟前
Articulation Point(割点)算法详解
算法·深度优先
热心市民小刘050542 分钟前
11.18二叉树中序遍历(递归)
数据结构·算法
brave and determined1 小时前
可编程逻辑器件学习(day24):异构计算:突破算力瓶颈的未来之路
人工智能·嵌入式硬件·深度学习·学习·算法·fpga·asic
未若君雅裁1 小时前
LeetCode 18 - 四数之和 详解笔记
java·数据结构·笔记·算法·leetcode
2501_941111461 小时前
高性能计算集群部署
开发语言·c++·算法
AIpanda8881 小时前
AI销冠系统和AI提效软件系统是什么?主要特点和应用场景有哪些?
算法
普通网友2 小时前
模板编译期机器学习
开发语言·c++·算法
普通网友2 小时前
C++与机器学习框架
开发语言·c++·算法