leetcode hot100 之 编辑距离

给你两个单词 word1word2, 请返回将 word1 转换成 word2 所使用的最少操作数 。

你可以对一个单词进行如下三种操作:

  • 插入一个字符
  • 删除一个字符
  • 替换一个字符

输入:word1 = “horse”, word2 = “ros”
输出:3
解释:
horse -> rorse (将 ‘h’ 替换为 ‘r’)
rorse -> rose (删除 ‘r’)
rose -> ros (删除 ‘e’)

原题链接:https://leetcode.cn/problems/edit-distance/

思路

以 dp[i][j] 表示 word1[0: i]、word2[0: j] 的编辑距离。

转移方程:
当 word1[i] == word2[j] 时,此时无需操作,dp[i][j] = dp[i-1][j-1]
当 word1[i] != word2[j] 时,dp[i][j] = min(dp[i-1][j-1], dp[i-1][j], dp[i][j-1]) + 1
这里 dp[i-1][j-1], dp[i-1][j], dp[i][j-1] 三项分别代表 替换、删除、增加。

边界条件:
当 i = 0 或 j = 0 时,显然 dp[i][0] 或 dp[0][j] 等于另一个子字符串的长度。即 dp[i][0] = i 、dp[0][j] = j

代码

class Solution {
public:
    int minDistance(string word1, string word2) {
        // if word1[i] == word2[j], dp[i][j] = dp[i-1][j-1]
        // else: dp[i][j] = min(dp[i-1][j-1], dp[i-1][j], dp[i][j-1]) + 1

        int m = word1.size();
        int n = word2.size();
        vector<vector<int>> dp(m+1, vector<int> (n+1, 0));

        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[i-1] == word2[j-1]) {
                    dp[i][j] = dp[i-1][j-1];
                } else {
                    dp[i][j] = min(min(dp[i-1][j-1], dp[i-1][j]), dp[i][j-1]) + 1;
                }
            }
        }
        return dp[m][n];
    }
};

相关推荐

  1. leetcode hot100 编辑距离

    2024-06-14 04:00:02       31 阅读
  2. LeetCodehot100

    2024-06-14 04:00:02       57 阅读
  3. 【LeetCode热题100】【多维动态规划】编辑距离

    2024-06-14 04:00:02       34 阅读
  4. 一个月速刷leetcodeHOT100 day02

    2024-06-14 04:00:02       37 阅读
  5. 一个月速刷leetcodeHOT100 day 01

    2024-06-14 04:00:02       94 阅读
  6. 一个月速刷leetcodeHOT100 day03

    2024-06-14 04:00:02       33 阅读
  7. 动态规划编辑距离(接上一个题)

    2024-06-14 04:00:02       56 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-14 04:00:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-14 04:00:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-14 04:00:02       82 阅读
  4. Python语言-面向对象

    2024-06-14 04:00:02       91 阅读

热门阅读

  1. 115. 素数筛选

    2024-06-14 04:00:02       38 阅读
  2. vue封装全局的防抖节流函数

    2024-06-14 04:00:02       32 阅读
  3. 用Python编写自动发送每日电子邮件报告的脚本

    2024-06-14 04:00:02       28 阅读
  4. SuntoryProgrammingContest2024(AtCoder Beginner Contest 357)

    2024-06-14 04:00:02       28 阅读
  5. trpc快速上手

    2024-06-14 04:00:02       29 阅读
  6. kotlin 中的字符

    2024-06-14 04:00:02       29 阅读