题解 | #计算字符串的编辑距离#

计算字符串的编辑距离

https://www.nowcoder.com/practice/3959837097c7413a961a135d7104c314

str1 = input()
str2 = input()
length_1 = len(str1)
length_2 = len(str2)
# 创建DP数组,考虑字符可能为空,外层是行,内层是列
dp = [[0 for i in range(length_1 + 1)] for j in range(length_2 + 1)]

# 初始化dp数组
for i in range(length_1 + 1):
    dp[0][i] = i
for j in range(length_2 + 1):
    dp[j][0] = j

# 遍历dp数组,先遍历行,再遍历列
for i in range(1, length_2 + 1):
    for j in range(1, length_1 + 1):

        if str2[i - 1] == str1[j - 1]:
            dp[i][j] = dp[i - 1][j - 1]

        else:
            dp[i][j] = min(dp[i - 1][j - 1], dp[i][j - 1], dp[i - 1][j]) + 1


print(dp[length_2][length_1])

全部评论

相关推荐

不愿透露姓名的神秘牛友
08-11 17:58
怎么感觉全世界都转码了
蜻蜓队长:其实很多转码的人本身是非常适合学计算机的,只是自己当年没选对专业😂
点赞 评论 收藏
分享
陆续:不可思议 竟然没那就话 那就我来吧 :你是我在牛客见到的最美的女孩
点赞 评论 收藏
分享
这一生如履薄冰:产品经理现在都要会微调大模型了吗
点赞 评论 收藏
分享
算法题感觉都挺简单的啊
投递哔哩哔哩等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务