【Golang】LeetCode 72. 编辑距离

72. 编辑距离

题目描述

思路

针对两个字符串,它们的编辑距离是对二者进行修改,最终使两个字符串相等的操作次数。我们将这两个字符串分别命名为AB,按照题意,我们总共可以采取六种操作,分别是:

  1. 删除A中的一个字符;
  2. A插入一个字符;
  3. A替换一个字符;
  4. 删除B中的一个字符;
  5. B插入一个字符;
  6. B替换一个字符;

实际上,上述操作集合是可以被简化的。我们每一次对这两个字符串进行修改的操作集合其实可以缩小为三种,分别是:

  1. A插入一个字符;
  2. B插入一个字符;
  3. 修改A当中的一个字符。

为什么可以缩小操作的集合?原因是在A插入一个字符其实蕴含了在B当中删除一个字符以使AB相等的操作;在B插入一个字符亦然;而修改A当中的一个字符其实蕴含了修改B当中的一个字符以使AB相等,二者的目的是一致的,因此操作等价。

基于上述分析,我们使用二维动态规划来解决这道题。我们声明dp,其维度是(m + 1, n + 1)mA的长度,nB的长度。dp[i][j]的含义就是令0...i0...j两个子串相等的编辑距离最小代价。显然,在初始时有dp[i][0] == i以及dp[0][j] == j,也就是从空字符串变为B[0:j]子串需要在A插入j个字符。

我们使用双重循环来对dp数组进行维护,每次dp[i][j]的数据来源有三处,分别是dp[i - 1][j] + 1dp[i][j - 1] + 1以及change_costdp[i - 1][j] + 1指的就是在0...i - 1子串追加一个字符来使得两个字符串相等;dp[i][j - 1] + 1与之类似;change_cost指的就是通过"更换A当中的一个字符来让子串相等的情况",此时需要分情况判断:如果A[i - 1] == B[j - 1](注意,dp1开始遍历,而AB的下标从0开始,因此这里需要-1以对应上下标),那么不需要替换字符,change_cost == dp[i - 1][j - 1];否则需要替换一个字符,change_cost == dp[i - 1][j - 1] + 1

状态转移方程是dp[i][j] = min(dp[i - 1][j] + 1, dp[i][j - 1] + 1, change_cost)

基于以上思路,我们来写代码解决这个问题。

Golang 题解

go 复制代码
func minDistance(word1 string, word2 string) int {
    m, n := len(word1), len(word2)
    dp := make([][]int, m + 1)
    for i := 0; i <= m; i ++ {
        dp[i] = make([]int, n + 1)
        dp[i][0] = i
        if i == 0 {
            for j := 0; j <= n; j ++ {
                dp[i][j] = j
            }
        }
    }

    for i := 1; i <= m; i ++ {
        for j := 1; j <= n; j ++ {
            change_cost := dp[i - 1][j - 1]
            if word1[i - 1] != word2[j - 1] {
                change_cost += 1
            }
            dp[i][j] = min(dp[i - 1][j] + 1, dp[i][j - 1] + 1, change_cost)
        }
    }

    return dp[m][n]
}
相关推荐
_OP_CHEN几秒前
【算法基础篇】(五十七)线性代数之矩阵乘法从入门到实战:手撕模板 + 真题详解
线性代数·算法·矩阵·蓝桥杯·c/c++·矩阵乘法·acm/icpc
天天爱吃肉82185 分钟前
【跨界封神|周杰伦×王传福(陶晶莹主持):音乐创作与新能源NVH测试,底层逻辑竟完全同源!(新人必看入行指南)】
python·嵌入式硬件·算法·汽车
im_AMBER6 分钟前
Leetcode 114 链表中的下一个更大节点 | 删除排序链表中的重复元素 II
算法·leetcode
xhbaitxl18 分钟前
算法学习day38-动态规划
学习·算法·动态规划
多恩Stone19 分钟前
【3D AICG 系列-6】OmniPart 训练流程梳理
人工智能·pytorch·算法·3d·aigc
历程里程碑21 分钟前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
pp起床22 分钟前
贪心算法 | part02
算法·leetcode·贪心算法
sin_hielo22 分钟前
leetcode 1653
数据结构·算法·leetcode
2501_9011478324 分钟前
面试必看:优势洗牌
笔记·学习·算法·面试·职场和发展
YuTaoShao34 分钟前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法二)排序 + 二分查找
数据结构·算法·leetcode