leetcode72. 编辑距离
题目
思路
dp[i][j]
代表 word1
到 i
位置转换成 word2
到 j
位置需要最少步数,所以,
当
word1[i] == word2[j]
,dp[i][j] = dp[i-1][j-1]
;
当word1[i] != word2[j]
,dp[i][j] = 1 + min(dp[i-1][j-1], dp[i-1][j], dp[i][j-1])
其中,dp[i-1][j-1]
表示替换操作,dp[i-1][j]
表示对word1
插入,dp[i][j-1]
表示对word2
插入。
注意,针对第一行,第一列要单独考虑,我们引入 ‘’ 下图所示,初始化如下所示:
代码
class Solution:def minDistance(self, word1: str, word2: str) -> int:dp = [[0] * (len(word2)+1) for _ in range(len(word1)+1)]for i in range(len(word1)+1):dp[i][0] = ifor j in range(len(word2)+1):dp[0][j] = jfor i in range(1, len(word1)+1):for j in range(1, len(word2)+1):if word1[i-1] == word2[j-1]:dp[i][j] = dp[i-1][j-1]else:dp[i][j] = 1 + min(dp[i-1][j-1], dp[i-1][j], dp[i][j-1])return dp[-1][-1]