当前位置: 首页 > article >正文

代码随想录算法训练营Day 55 || 583. 两个字符串的删除操作、72. 编辑距离

583. 两个字符串的删除操作

力扣题目链接(opens new window)

给定两个单词 word1 和 word2,找到使得 word1 和 word2 相同所需的最小步数,每步可以删除任意一个字符串中的一个字符。

示例:

  • 输入: "sea", "eat"
  • 输出: 2
  • 解释: 第一步将"sea"变为"ea",第二步将"eat"变为"ea"

动态规划求解 LCS
  1. 状态定义:创建一个二维数组 dp,其中 dp[i][j] 表示 word1 的前 i 个字符和 word2 的前 j 个字符的最长公共子序列的长度。
  2. 状态初始化:初始化 dp 数组的第一行和第一列为0,因为空字符串与任何字符串的最长公共子序列长度为0。
  3. 状态转移
    • 如果 word1[i - 1] == word2[j - 1],则 dp[i][j] = dp[i - 1][j - 1] + 1
    • 如果不相等,则 dp[i][j] = max(dp[i - 1][j], dp[i][j - 1])
  4. 计算删除步骤len(word1) + len(word2) - 2 * dp[len(word1)][len(word2)]。这是因为 dp[len(word1)][len(word2)] 是两个字符串的最长公共子序列长度,从每个字符串长度中减去这个值,然后相加,就是总共需要删除的字符数。
def minDistance(word1: str, word2: str) -> int:
    m, n = len(word1), len(word2)
    dp = [[0] * (n + 1) for _ in range(m + 1)]

    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if word1[i - 1] == word2[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
            else:
                dp[i][j] = max(dp[i - 1][j], dp[i][j - 1])

    return m + n - 2 * dp[m][n]

# 测试代码
word1 = "sea"
word2 = "eat"
print(minDistance(word1, word2))  # 应该输出 2

72. 编辑距离

力扣题目链接(opens new window)

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

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

  • 插入一个字符

  • 删除一个字符

  • 替换一个字符

  • 示例 1:

  • 输入:word1 = "horse", word2 = "ros"

  • 输出:3

  • 解释: horse -> rorse (将 'h' 替换为 'r') rorse -> rose (删除 'r') rose -> ros (删除 'e')

  • 示例 2:

  • 输入:word1 = "intention", word2 = "execution"

  • 输出:5

  • 解释: intention -> inention (删除 't') inention -> enention (将 'i' 替换为 'e') enention -> exention (将 'n' 替换为 'x') exention -> exection (将 'n' 替换为 'c') exection -> execution (插入 'u')
    解释: 意图 -> inention (删除 't') inention -> enention (将 'i' 替换为 'e') enention -> exention (将 'n' 替换为 'x') exention -> exection (将 'n' 替换为 'c') exection -> execution (插入 'u')

提示:

  • 0 <= word1.length, word2.length <= 500
  • word1 和 word2 由小写英文字母组成 

动态规划
  1. 状态定义:创建一个二维数组 dp,其中 dp[i][j] 表示将 word1 的前 i 个字符转换成 word2 的前 j 个字符所需的最少操作数。
  2. 状态初始化
    • dp[0][j] 表示将空字符串转换为 word2 的前 j 个字符,需要 j 次插入操作。
    • dp[i][0] 表示将 word1 的前 i 个字符转换为空字符串,需要 i 次删除操作。
  3. 状态转移
    • 如果 word1[i - 1] == word2[j - 1],则 dp[i][j] = dp[i - 1][j - 1],无需额外操作。
    • 如果不相等,考虑以下三种操作:
      • 插入:dp[i][j - 1] + 1
      • 删除:dp[i - 1][j] + 1
      • 替换:dp[i - 1][j - 1] + 1
    • 选择上述操作中的最小值作为 dp[i][j] 的值。
  4. 最终结果dp[len(word1)][len(word2)]
def minDistance(word1: str, word2: str) -> int:
    m, n = len(word1), len(word2)
    dp = [[0] * (n + 1) for _ in range(m + 1)]

    for i in range(m + 1):
        dp[i][0] = i
    for j in range(n + 1):
        dp[0][j] = j

    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if word1[i - 1] == word2[j - 1]:
                dp[i][j] = dp[i - 1][j - 1]
            else:
                dp[i][j] = min(dp[i - 1][j], dp[i][j - 1], dp[i - 1][j - 1]) + 1

    return dp[m][n]

# 测试代码
word1 = "horse"
word2 = "ros"
print(minDistance(word1, word2))  # 应该输出 3

 

#

 

 


http://www.kler.cn/a/133548.html

相关文章:

  • HarmonyOS Next构建工具 lycium 原理介绍
  • 日期问题--模板
  • 99.12 金融难点通俗解释:毛利率
  • 编程界“华山论剑”:PHP与Go,谁主沉浮?
  • 通过视觉语言模型蒸馏进行 3D 形状零件分割
  • NIO | 什么是Java中的NIO —— 结合业务场景理解 NIO (一)
  • 力扣-路径总和问题
  • 【SpringBoot3+Vue3】三【实战篇】-后端(优化)
  • 大数据数仓建模基础理论【维度表、事实表、数仓分层及示例】
  • [开源]基于 AI 大语言模型 API 实现的 AI 助手全套开源解决方案
  • OpenCV快速入门:图像形态学操作
  • PPT转PDF转换器:便捷的批量PPT转PDF转换软件
  • WSA子系统(一)
  • Vue3-watchEffect函数
  • 220V交流转直流的简易电源设计
  • 高效背单词——单词APP安利
  • Jmeter- Beanshell语法和常用内置对象(网络整理)
  • 【SpringBoot3+Vue3】四【实战篇】-前端(vue基础)
  • 短视频ai剪辑分发账号矩阵系统(招商oem)----源头技术开发
  • 【Spring总结】注解开发
  • 刷题学习记录(攻防世界)
  • Vue.js正式环境中配置多个请求的URL
  • 【【SOC设计之 数据回路从 DMA到 FIFO再到BRAM 再到FIFO 再写回DMA】】
  • centos虚拟机无法接受消息(防火墙)
  • 工作中积累的对K8s的就绪和存活探针的一些认识
  • Docker入门学习笔记