P2758 编辑距离 线性DP题解

P2758 编辑距离 题解

    洛谷题目链接

  题目描述概括:A,B两个字符串,对A字符串进行删除/添加/修改字符操作,求A到B的最小操作次数

本题可以用线性DP来解决,设f[i][j]表示字符串A的前i个字符变为字符串B的前j个字符的最少操作次数,状态转移时一共有两种情况:

 1.A[i]=B[j] 那么A的第i个字符和B的第j个字符正好对应,不需要修改,此时f[i][j]=f[i-1][j-1]

if(s1[i-1]==s2[j-1])f[i][j]=f[i-1][j-1];

2.A[i]!=B[j] 此时可以有三种操作方式来到达目标状态,即删除/添加/修改

    删除:f[i][j]=f[i-1][j]+1

    添加:f[i][j]=f[i][j-1]+1

    修改:f[i][j]=f[i-1][j-1]+1

else f[i][j]=min(min(f[i][j-1],f[i-1][j]),f[i-1][j-1])+1;

f数组需要初始化,在i=0时全部需要添加,所以f[0][j]=j,j=0时全部都需要删除,所以f[i][0]=i

for(int i=1;i<=len1;i++)f[i][0]=i;
for(int i=1;i<=len2;i++)f[0][i]=i;

最后f[lenA][lenB]就是答案

AC代码:

#include <cstdio>
#include <cstring>
#include <algorithm>

using namespace std;

const int maxn=2e3+7;
char s1[maxn],s2[maxn];
int f[maxn][maxn];

int main(){
scanf("%s%s",s1,s2);
int len1=strlen(s1),len2=strlen(s2);

for(int i=1;i<=len1;i++)f[i][0]=i; //初始化
for(int i=1;i<=len2;i++)f[0][i]=i;

for(int i=1;i<=len1;i++){
for(int j=1;j<=len2;j++){
if(s1[i-1]==s2[j-1])f[i][j]=f[i-1][j-1]; //第一种情况
else f[i][j]=min(min(f[i][j-1],f[i-1][j]),f[i-1][j-1])+1; //第二种情况
}
}
printf("%d",f[len1][len2]);
return 0;
}

 

原创:https://www.panoramacn.com
源码网提供WordPress源码,帝国CMS源码discuz源码,微信小程序,小说源码,杰奇源码,thinkphp源码,ecshop模板源码,微擎模板源码,dede源码,织梦源码等。

专业搭建小说网站,小说程序,杰奇系列,微信小说系列,app系列小说

P2758 编辑距离 线性DP题解

免责声明,若由于商用引起版权纠纷,一切责任均由使用者承担。

您必须遵守我们的协议,如果您下载了该资源行为将被视为对《免责声明》全部内容的认可-> 联系客服 投诉资源
www.panoramacn.com资源全部来自互联网收集,仅供用于学习和交流,请勿用于商业用途。如有侵权、不妥之处,请联系站长并出示版权证明以便删除。 敬请谅解! 侵权删帖/违法举报/投稿等事物联系邮箱:2640602276@qq.com
未经允许不得转载:书荒源码源码网每日更新网站源码模板! » P2758 编辑距离 线性DP题解
关注我们小说电影免费看
关注我们,获取更多的全网素材资源,有趣有料!
120000+人已关注
分享到:
赞(0) 打赏

评论抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

您的打赏就是我分享的动力!

支付宝扫一扫打赏

微信扫一扫打赏