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

2024-03-25 02:20

本文主要是介绍动态规划16 | ● 583. 两个字符串的删除操作 ● *72. 编辑距离,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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]

这篇关于动态规划16 | ● 583. 两个字符串的删除操作 ● *72. 编辑距离的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/843564

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多