代码随想录算法训练营第五十五 | ● 583. 两个字符串的删除操作 ● 72. 编辑距离

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

https://programmercarl.com/0583.两个字符串的删除操作.html

cpp 复制代码
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 i=0;i<=word2.size();i++)
            dp[0][i]=i;
        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];
                    //这里的逻辑一开始考虑错了
                    //dp[i][j] = min(dp[i-1][j]-1,min(dp[i][j-1]-1,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()];
    }
};

72. 编辑距离

https://programmercarl.com/0072.编辑距离.html

cpp 复制代码
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 i=0;i<=word2.size();i++)
            dp[0][i]=i;
        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],dp[i-1][j]})+1;
                    //dp[i][j] = min(dp[i-1][j]+1,dp[i][j-1]+1);
                }
            }
        }
        return dp[word1.size()][word2.size()];
    }
};

这类题目的代码大致思路:

相关推荐
信奥卷王11 分钟前
2026年03月GESPC++二级真题解析(含视频)
算法
从零开始学习人工智能14 分钟前
国产阿特拉斯无人机蜂群核心算法(一)
算法·无人机
励志的小陈1 小时前
双指针算法--移除元素、删除有序数组中的重复项、合并两个有序数组
算法
Summer_Uncle1 小时前
【QT学习】Qt界面布局的生命周期和加载时机
c++·qt
小CC吃豆子1 小时前
C++ 继承
开发语言·c++
hoiii1871 小时前
Mean Shift目标跟踪算法MATLAB实现
算法·matlab·目标跟踪
alphaTao1 小时前
LeetCode 每日一题 2026/3/23-2026/3/29
服务器·windows·leetcode
励志的小陈1 小时前
复杂度算法题——旋转数组(三种思路)
c语言·数据结构·算法
tankeven1 小时前
HJ151 模意义下最大子序列和(Easy Version)
c++·算法
fengenrong2 小时前
20260325
开发语言·c++