力扣热门100题之编辑距离

核心思路

  • dp[i][j]:把 word1i 个字符 → 变成 word2j 个字符,最少操作数
  • 三种操作对应三种来源:
    1. 替换dp[i-1][j-1] + 1
    2. 删除dp[i-1][j] + 1
    3. 插入dp[i][j-1] + 1
  • 如果字符相等 ,就不用操作:dp[i][j] = dp[i-1][j-1]

通俗解释

  • dp[i][0] = i:word2 为空,word1 要删 i 次
  • dp[0][j] = j:word1 为空,要插 j 次

字符不同时:

  1. 替换 :把 word1 第 i 个换成 word2 第 j 个→ 前面 i-1,j-1 + 1 次
  2. 删除 :删掉 word1 第 i 个→ 前面 i-1,j + 1 次
  3. 插入 :给 word1 插一个字符→ 前面 i,j-1 + 1 次

三者取最小就是当前最优

完整代码实现:

复制代码
class Solution {
    public int minDistance(String word1, String word2) {
        int m = word1.length();
        int n = word2.length();

        int[][] dp = new int[m + 1][n + 1];

        // 初始化:一个为空,另一个全删/全插
        for (int i = 0; i <= m; i++) dp[i][0] = i;
        for (int j = 0; j <= n; j++) dp[0][j] = j;

        for (int i = 1; i <= m; i++) {
            for (int j = 1; j <= n; j++) {
                // 字符相同,不用操作
                if (word1.charAt(i-1) == word2.charAt(j-1)) {
                    dp[i][j] = dp[i-1][j-1];
                } else {
                    // 取替换、删除、插入 三者最小 +1
                    dp[i][j] = Math.min(
                        Math.min(dp[i-1][j-1], dp[i-1][j]),
                        dp[i][j-1]
                    ) + 1;
                }
            }
        }
        return dp[m][n];
    }
}
相关推荐
Wave8452 小时前
C++继承详解
开发语言·c++·算法
睡觉就不困鸭2 小时前
第9天 两数之和
算法·哈希算法·散列表
贾斯汀玛尔斯3 小时前
每天学一个算法--动态规划(Dynamic Programming, DP)
算法·动态规划
水木流年追梦3 小时前
CodeTop 热门题目汇总hot300题
算法·leetcode·职场和发展
努力努力再努力wz3 小时前
【Linux网络系列】万字硬核解析网络层核心:IP协议到IP 分片重组、NAT技术及 RIP/OSPF 动态路由全景
java·linux·运维·服务器·数据结构·c++·python
小糖学代码3 小时前
LLM系列:2.pytorch入门:3.基本优化思想与最小二乘法
人工智能·python·算法·机器学习·ai·数据挖掘·最小二乘法
爱写代码的倒霉蛋3 小时前
天梯赛备赛经验分享(基础版)
经验分享·算法
f3iiish3 小时前
2078. 两栋颜色不同且距离最远的房子 力扣
算法·leetcode
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:拼数
c++·算法·贪心·csp·信奥赛·排序贪心·拼数