力扣第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()];
    }
};
相关推荐
(●—●)橘子……几秒前
3643.垂直翻转子矩阵 练习理解
笔记·python·学习·算法·leetcode·矩阵
小白程序员成长日记3 分钟前
2025.12.10 力扣每日一题
算法·leetcode
立志成为大牛的小牛7 分钟前
数据结构——五十七、插入排序(王道408)
数据结构·笔记·程序人生·考研·算法
兩尛8 分钟前
猴子爬山od
算法·华为od
亭上秋和景清9 分钟前
计算器回调函数
c语言·数据结构·算法
青山的青衫10 分钟前
【优先级队列(堆)+排序】LeetCode hot100+面试高频
算法·leetcode·面试
第二只羽毛16 分钟前
基于Deep Web爬虫的当当网图书信息采集
大数据·开发语言·前端·爬虫·算法
Ayanami_Reii16 分钟前
详解Splay平衡树
数据结构·算法·线段树·主席树·持久化线段树
前端小白在前进21 分钟前
★力扣刷题:LRU缓存
spring·leetcode·缓存
JiaJZhong30 分钟前
560. 和为 K 的子数组
数据结构·算法