美文网首页
72.编辑距离

72.编辑距离

作者: 最尾一名 | 来源:发表于2020-03-02 11:27 被阅读0次

原题

https://leetcode-cn.com/problems/edit-distance/

解题思路

题目看上去好像不简单,但我们仔细分析之后,可以看出满足动态规划的条件。

假如用 dp[i][j] 表示 word1 的前 i 位 和 word2 的前 j 位之间的最少操作数。
那么考虑以下两种情况:

  • word1[i-1] === word2[j-1] (即 word1 的第 i 位和 word2 的第 j 位相同):
    可以从以下两种情况经过一步操作使得 word1 的前 i 位 和 word2 的前 j 位相同:

    • word1 的前 i - 1 位通过 dp[i-1][j] 次转变后和 word2 的前 j 位相同,增加一位
    • word1 的前 i 位通过 dp[i][j-1] 次转变后和 word2 的前 j - 1 位相同,删除一位
  • word1[i-1] !== word2[j-1]:
    可以从以下三种情况经过一步操作使得 word1 的前 i 位 和 word2 的前 j 位相同:

    • word1 的前 i - 1 位通过 dp[i-1][j] 次转变后和 word2 的前 j 位相同,增加一位
    • word1 的前 i 位通过 dp[i][j-1] 次转变后和 word2 的前 j - 1 位相同,删除一位
    • word1 的前 i - 1 位通过 dp[i-1][j-1] 次转变后和 word2 的前 j - 1 位相同,替换一位

边界情况:
- dp[i][0] := i (删除 i 位)
- dp[-][j] := j (增加 j 位)

代码

/**
 * @param {string} word1
 * @param {string} word2
 * @return {number}
 */
var minDistance = function(word1, word2) {
    const m = word1.length, n = word2.length;
    const dp = new Array();
    for (let i = 0; i <= m; ++i) {
        let temp = new Array();
        for (let j = 0; j <= n; ++j) {
            temp.push(0);
        }
        dp.push(temp);
    }
    for (let i = 0; i <= m; ++i) {
        dp[i][0] = i;
    }
    for (let j = 0; j <= n; ++j) {
        dp[0][j] = j;
    }
    for (let i = 1; i <= m; ++i) {
        for (let j = 1; j <= n; ++j) {
            if (word1[i-1] === word2[j-1]) {
                dp[i][j] = 1 + Math.min(dp[i-1][j], dp[i][j-1], dp[i-1][j-1] - 1);
            } else {
                dp[i][j] = 1 + Math.min(dp[i-1][j], dp[i][j-1], dp[i-1][j-1]);
            }
        }
    }
    return dp[m][n];
};

复杂度

  • 时间复杂度 O(MN)
  • 空间复杂度 O(MN)

相关文章

  • 72. Edit Distance, 编辑距离

    72. Edit Distance, 编辑距离

  • 72. 编辑距离

    题目 思路 动态规划的题目 递归 上述一个递归过程: 如果字符串最后一个相等,两个字符串-1 如果不相等:2.1 ...

  • 72. 编辑距离

    给定两个单词 word1 和 word2,计算出将 word1 转换成 word2 所使用的最少操作数 。你可以对...

  • 72.编辑距离

    原题 https://leetcode-cn.com/problems/edit-distance/ 解题思路 题...

  • 72. 编辑距离

    72. 编辑距离 给你两个单词 word1 和 word2,请你计算出将 word1 转换成 word2 所使用的...

  • 72. 编辑距离

    题目:给你两个单词word1和word2,计算将word1转成word2所需要的的最少操作数。你可以对一个单词进行...

  • 72. 编辑距离

    解法

  • 72. 编辑距离

    ``` classSolution{ publicintminDistance(Stringword1,Strin...

  • 72.编辑距离

    72. 编辑距离[https://leetcode-cn.com/problems/edit-distance/]...

  • 72.编辑距离

    72.编辑距离[https://leetcode.cn/problems/edit-distance/] 给你两个...

网友评论

      本文标题:72.编辑距离

      本文链接:https://www.haomeiwen.com/subject/qqupkhtx.html