leetcode 每日一题 72. 编辑距离

Posted nil_f

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode 每日一题 72. 编辑距离相关的知识,希望对你有一定的参考价值。

动态规划

思路:

用dp[i][j]表示A的前 i 个字母和B的前 j 个字母之间的编辑距离。

则边缘部分dp[i][0] = i ,dp[0][j] = j ,因为要把A的前i个字母变成B的前0个字母也就是空串需要删除A的i个字母即可。同理要把A的空串变成B的前j个字母,需要在A中添加B的前j个字符即可。

下面建立dp[i][j]的状态转移方程,根据题意dp[i][j]可由三种方式得到:

①dp[i][j] = dp[i][j-1]+1 , 因为dp[i][j-1]表示A的前i到B的前j-1编辑距离,那么只需要在A中的i+1的位置添加B的第j个字母即可。

例如: A:cat   B:cats

dp[3][3] = 0  dp[3][4] = dp[3][3]+1 = 1 (A前3个字母cat变成B前4个字母cats,只需要在后面加个e即可)

②dp[i][j] = dp[i-1][j]+1 , 因为dp[i-1][j]表示A的前i-1到B的前j编辑距离, 那么只需要在A中删除第i个位置字母即可。 

例如:  A: cat  B:cats

dp[2][2] = 0  dp[3][2] = dp[2][2] +1 = 1 (A的前3个字母cat变成B前2个字母ca,只需删除A的第3个字母t即可)

③如果A[i] = B[j] , 则dp[i][j] = dp[i-1][j-1],因为如果A第i个字母和B第j个字母相等,那么只需要讨论A的前i-1如何变成B的前j-1即可。

例如: A:cat  B:cats

A[3]=B[3]=t ,dp[3][3] = dp[2][2] = 0

如果A[i] != B[j],则dp[i][j] = dp[i-1][j-1]+1, 因为如果A第i个字母和B第j个字母相等,那么只需要在A的前i-1和B的前j-1编辑匹配的基础上,将A的第i个字母替换为B的第j个字母即可。

由于要找到最小的编辑距离只需要取三种方式中的最小值即可 min(①,②,③)

代码:

class Solution:
    def minDistance(self, word1: str, word2: str) -> int:
        n = len(word1)
        m = len(word2)
        if n * m == 0:
            return n + m
        D = [ [0] * (m + 1) for _ in range(n + 1)]
        for i in range(n + 1):
            D[i][0] = i
        for j in range(m + 1):
            D[0][j] = j
        for i in range(1, n + 1):
            for j in range(1, m + 1):
                left = D[i - 1][j] + 1
                down = D[i][j - 1] + 1
                left_down = D[i - 1][j - 1] 
                if word1[i - 1] != word2[j - 1]:
                    left_down += 1
                D[i][j] = min(left, down, left_down)
        return D[n][m]

 

以上是关于leetcode 每日一题 72. 编辑距离的主要内容,如果未能解决你的问题,请参考以下文章

《LeetCode之每日一题》:72.转置矩阵

leetcode每日一题汉明距离

《LeetCode之每日一题》:50.汉明距离总和

《LeetCode之每日一题》:42.汉明距离

Leetcode 72.编辑距离

leetcode 72. Edit Distance 编辑距离(中等)