动态规划16 | ● 583. 两个字符串的删除操作 ● *72. 编辑距离

news/2024/11/13 0:14:02/

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

https://programmercarl.com/0583.%E4%B8%A4%E4%B8%AA%E5%AD%97%E7%AC%A6%E4%B8%B2%E7%9A%84%E5%88%A0%E9%99%A4%E6%93%8D%E4%BD%9C.html

  • 考点
    • 子序列问题
  • 我的思路
    • dp[i][j]的含义是,当两个字符串分别取前i和j个元素时,对应的最少相等删除步数是多少
    • 递推公式为,如果两个字符串第i和j个元素恰好相等,则dp值应等于不再考虑这两个元素的dp值即dp[i - 1][j - 1];如果i和j不相等,则dp值应等于删除任一元素后的dp值取较小者即min(dp[i - 1][j] + 1, dp[i][j - 1] + 1)
    • 初始化,由于递推公式依赖于当前元素在二维矩阵中的左上元素,因此需要对二维矩阵的第一行和第一列进行初始化,初始化原则是,如果当前位置两字符串的元素相等,则dp等于将较长者除当前元素外其它元素均删除所需要的步数;如果不相等,dp等于不考虑较长字符串当前元素后所需要的最少步数和不考虑较短字符串当前元素(也就是令较短字符串为空)时所需要的最少步数中取较小者
  • 视频讲解关键点总结
    • 和我的思路一致
  • 我的思路的问题
  • 代码书写问题
  • 可执行代码
class Solution:def minDistance(self, word1: str, word2: str) -> int:dp = [[0] * len(word2) for _ in range(len(word1))]if word1[0] == word2[0]:dp[0][0] = 0else:dp[0][0] = 2for i in range(1, len(word1)):if word1[i] == word2[0]:dp[i][0] = ielse:dp[i][0] = min(dp[i - 1][0] + 1, i + 2)for i in range(1, len(word2)):if word1[0] == word2[i]:dp[0][i] = ielse:dp[0][i] = min(dp[0][i - 1] + 1, i + 2)for i in range(1, len(word1)):for j in range(1, len(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][j - 1] + 1)return dp[-1][-1]

*72. 编辑距离

https://programmercarl.com/0072.%E7%BC%96%E8%BE%91%E8%B7%9D%E7%A6%BB.html

  • 考点
    • 子序列问题
  • 我的思路
    • dp含义和上一题整体思路相同
    • 递推公式两元素相等的情况和上一题相同,但是两元素不相等的情况只考虑到了删除当前word1元素的解法
    • 初始化较为简单,不展开说了
  • 视频讲解关键点总结
    • 我的思路的问题就在,递推公式里,如果两元素不相等,应该有三种处理方式(增、删、改),而我只实现了删的操作,其中增加一个元素也就是增加和word2当前元素相同的元素,也就是不需要考虑word2当前元素;删除也就是不考虑word1当前元素;改也就是不需要考虑word1和word2的当前元素
  • 我的思路的问题
    • 漏了两种情况
  • 代码书写问题
  • 可执行代码
class Solution:def minDistance(self, word1: str, word2: str) -> int:if word1 == '' and word2 == '':return 0elif word1 == '':return len(word2)elif word2 == '':return len(word1)dp = [[0] * len(word2) for _ in range(len(word1))]if word1[0] == word2[0]:dp[0][0] = 0else:dp[0][0] = 1for i in range(1, len(word1)):if word1[i] == word2[0]:dp[i][0] = ielse:dp[i][0] = dp[i - 1][0] + 1for i in range(1, len(word2)):if word1[0] == word2[i]:dp[0][i] = ielse:dp[0][i] = dp[0][i - 1] + 1for i in range(1, len(word1)):for j in range(1, len(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 - 1] + 1, dp[i][j - 1] + 1)return dp[-1][-1]

http://www.ppmy.cn/news/1394588.html

相关文章

详解JavaScript中this指向

this 原理 this 是一个指针型变量,它指向当前函数的运行环境。 1.内存的数据结构 var obj { foo: 5 };2.函数 var obj { foo: function () {} };引擎会将函数单独保存在内存中,然后再将函数的地址赋值给foo属性的value属性。 由于函数是一个单独的…

一些规律、现象

图文部分由COPILOT生成。 规律详情 墨菲定律 墨菲定律(Murphys Law) 一件事可能出错时就一定会出错。 图:AI生成 破窗效应 破窗效应(Broken windows theory)是犯罪心理学理论。以一幢有少许破窗的建筑为例,如果那些窗没修理好&#xff0…

如何学好Python语言

学习Python:一场充满探索与实践的编程之旅 Python,作为一种解释型、交互式和面向对象的编程语言,近年来在数据科学、人工智能、Web开发等多个领域得到了广泛的应用。掌握Python,不仅可以提升个人的编程技能,还能够为未…

C语言动态内存的管理

前言 本篇博客就来探讨一下动态内存,说到内存,我们以前开辟空间大小都是固定的,不能调整这个空间大小,于是就有动态内存,可以让我们自己选择开辟多少空间,更加方便,让我们一起来看看动态内存的有…

MC0207 中转站

物流业为了降低物流成本,提高物流效率,运输过程中通常不会由始发地直达目的地,而是经由多个中转站中转,最终到达目的地。最常见的便是快递业,由于中转站有很多,要想将所有中转站两两互通代价过高&#xff0…

.NET高级面试指南专题二十二【 数据库索引】

数据库索引是一种数据结构,用于提高数据库查询效率。它们类似于书籍的目录,能够快速指引数据库引擎去查找特定的数据行。 索引的原理是通过在数据库表的列上创建一个有序的数据结构,通常是 B 树或 B 树,使得数据库引擎可以更快地定…

第三十一章 配置 Web Gateway 的默认参数 - 事件记录参数

文章目录 第三十一章 配置 Web Gateway 的默认参数 - 事件记录参数 第三十一章 配置 Web Gateway 的默认参数 - 事件记录参数 事件日志级别字段指定 Web Gateway 写入 Web Gateway 事件日志的信息。日志记录选项定义为一串字符,每个字符代表一个日志记录命令。此处…

【无人机综合考试题】

1.请选择出哪一个功能选项,在手动遥控飞行时,可以改变各通道的操作灵敏度? 行程比例在手动遥控飞行时,可以改变各通道的操作灵敏度 用于起降的遥控器中 THR、ELE 通道分别控制多旋翼无人机的什么运动? AIL(左、右移动)RUD(左、右水平旋转…