lab13_大作业_最短编辑距离问题

1:问题
给定一个源串和目标串,能够对源串进行如下操作:
在任意位置上插入一个字符;
替换任意字符;
删除任意字符。
写一个程序,实现返回最小操作次数,使得对源串进行上述这些操作后等于目标串(源串和目标串的长度都小于2000)。
2:解析
一般情况下,我们要想得到将src[1…i]经过最少次数的增加,删除,或者替换操作就转变为dest[1…j],那么我们就必须在之前可以以最少次数的增加,删除,或者替换操作,使得现在串src和串dest只需要再做一次操作或者不做就可以完成源串src[1…i]到目标串dest[1…j]的转换。若源串的第i个字符与目标串的第j个字符相同,不需要进行操作,即:当src[i]=dest[j]时,d[i][j]=d[i-1][j-1];当src[i]与dest[j]不相同时,修改一个字符可以有三种操作方式:

   (1) 在src[i]处插入一个与dest[j]处相同的字符,即d[i][j]=d[i][j-1]+1;

   (2) 在src[i]处删除那个不相同的字符,即d[i][j]=d[i-1][j]+1;

   (3) 在src[i]处替换一个与dest[j]处相同的字符,即d[i][j]=d[i-1][j-1]+1;

故d[i][j]=min{d[i][j-1]+1,d[i-][j]+1,d[i-1][j-1]+1}。(每一个字符修改都执行最小的操作数)
图解:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
3:分析
该算法需要遍历两个字符串,所以算法复杂度为O(m*n)
4:源码
最短编辑数
5:结果展示
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值