解题思路:不要想着怎么去更改字符操作,算出最优解就好了
注意事项:
参考代码:
#include<bits/stdc++.h>
using namespace std;
int n,m;
char a[100],b[100];
int f[100][100];
int main()
{
cin>>a+1;
cin>>b+1;
n=strlen(a+1);
m=strlen(b+1);
for(int i=0;i<=n;i++)
f[0][i]=i;
for(int i=0;i<=m;i++)
f[i][0]=i;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
f[i][j]=min(f[i-1][j]+1,f[i][j-1]+1);
if(a[i]!=b[j])
f[i][j]=min(f[i][j],f[i-1][j-1]+1);
else
f[i][j]=min(f[i][j],f[i-1][j-1]);
}
}
cout<<f[n][m];
return 0;
}
0.0分
0 人评分
C语言训练-谁家孩子跑最慢* (C语言代码)浏览:1507 |
小九九 (C语言代码)浏览:817 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:639 |
奖学金 (C++代码)浏览:2005 |
C语言训练-排序问题<2> (C++代码)浏览:880 |
A+B for Input-Output Practice (V) (C++代码)浏览:450 |
【计算两点间的距离】 (C语言代码)浏览:879 |
简单的a+b (C语言代码)浏览:520 |
C语言程序设计教程(第三版)课后习题10.4 (C语言代码)浏览:665 |
C语言程序设计教程(第三版)课后习题6.8 (C语言代码)浏览:763 |