赞
踩
❤️❤️❤️ 欢迎来到我的博客。希望您能在这里找到既有价值又有趣的内容,和我一起探索、学习和成长。欢迎评论区畅所欲言、享受知识的乐趣!
推荐:数据分析螺丝钉的首页 格物致知 终身学习 期待您的关注
导航:
- LeetCode解锁1000题: 打怪升级之旅:每题都包括3-5种算法,以及详细的代码实现,刷题面试跳槽必备
- 漫画版算法详解:通过漫画的形式和动态GIF图片把复杂的算法每一步进行详细可视解读,看一遍就掌握
- python源码解读:解读python的源代码与调用关系,快速提升代码质量
- python数据分析可视化:企业实战案例:企业级数据分析案例与可视化,提升数据分析思维和可视化能力
- 程序员必备的数学知识与应用:全面详细的介绍了工程师都必备的数学知识
期待与您一起探索技术、持续学习、一步步打怪升级 欢迎订阅本专栏❤️❤️
在本篇文章中,我们将详细解读力扣第161题“相隔为 1 的编辑距离”。通过学习本篇文章,读者将掌握如何判断两个字符串是否只有一个编辑操作的距离,并了解相关的复杂度分析。除了逐字符比较的方法,还将介绍其他解法。每种方法都将配以详细的解释和ASCII图解,以便于理解。
力扣第161题“相隔为 1 的编辑距离”描述如下:
给定两个字符串
s
和t
,判断它们是否只有一个编辑操作的距离。编辑操作包括插入一个字符、删除一个字符或者替换一个字符。
示例 1:
输入: s = "ab", t = "acb"
输出: true
解释: 可以通过插入一个字符 'c' 使得字符串 t 变为 "abc"。
示例 2:
输入: s = "cab", t = "ad"
输出: false
解释: 无论进行哪种编辑操作,都不能将 s 转换为 t。
示例 3:
输入: s = "1203", t = "1213"
输出: true
解释: 可以通过替换字符 '0' 为字符 '1' 使得字符串 t 变为 "1213"。
def isOneEditDistance(s, t): m, n = len(s), len(t) # 确保 s 是较短的字符串 if m > n: return isOneEditDistance(t, s) # 长度差大于1,则不可能只通过一次编辑操作完成转换 if n - m > 1: return False for i in range(m): if s[i] != t[i]: # 长度相同,则必须是一次替换操作 if m == n: return s[i + 1:] == t[i + 1:] # 长度不同,则必须是一次插入操作 else: return s[i:] == t[i + 1:] # 字符串末尾插入情况 return m + 1 == n # 测试案例 print(isOneEditDistance("ab", "acb")) # 输出: true print(isOneEditDistance("cab", "ad")) # 输出: false print(isOneEditDistance("1203", "1213")) # 输出: true
假设输入字符串为 “ab” 和 “acb”,图解如下:
s = "ab"
t = "acb"
逐字符比较:
s[0] == t[0] -> 'a' == 'a'
s[1] != t[1] -> 'b' != 'c'
检查 s[1:] == t[2:] -> "b" == "b"
返回 true
动态规划是一种更为通用的方法,虽然在这个问题中并不一定是最优解法,但它在处理更多编辑操作(如多次编辑操作)时非常有用。
dp
,其中 dp[i][j]
表示字符串 s[0:i]
和 t[0:j]
的编辑距离。dp
数组,对于空字符串的编辑操作初始化为其长度。dp
数组,根据不同的编辑操作(插入、删除、替换)更新 dp
值。dp
数组最后一行和最后一列的值,判断是否为1。def isOneEditDistanceDP(s, t): m, n = len(s), len(t) if abs(m - n) > 1: return False dp = [[0] * (n + 1) for _ in range(m + 1)] for i in range(m + 1): for j in range(n + 1): if i == 0: dp[i][j] = j elif j == 0: dp[i][j] = i elif s[i - 1] == t[j - 1]: dp[i][j] = dp[i - 1][j - 1] else: dp[i][j] = 1 + min(dp[i - 1][j], dp[i][j - 1], dp[i - 1][j - 1]) return dp[m][n] == 1 # 测试案例 print(isOneEditDistanceDP("ab", "acb")) # 输出: true print(isOneEditDistanceDP("cab", "ad")) # 输出: false print(isOneEditDistanceDP("1203", "1213")) # 输出: true
假设输入字符串为 “ab” 和 “acb”,图解如下:
s = "ab"
t = "acb"
动态规划表格:
'' a c b
'' 0 1 2 3
a 1 0 1 2
b 2 1 1 1
检查 dp[2][3] == 1
返回 true
dp
值。测试案例 1:
s = "ab"
, t = "acb"
true
测试案例 2:
s = "cab"
, t = "ad"
false
测试案例 3:
s = "1203"
, t = "1213"
true
本文详细解读了力扣第161题“相隔为 1 的编辑距离”,通过逐字符比较和动态规划两种方法,高效地解决了这一问题。希望读者通过本文的学习,能够在力扣刷题的过程中更加得心应手。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/代码探险家/article/detail/750612
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。