解题思路:不要想着怎么去更改字符操作,算出最优解就好了
注意事项:
参考代码:
#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语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:609 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:551 |
A+B for Input-Output Practice (VII) (C语言代码)浏览:521 |
数字游戏 (C++代码)浏览:1177 |
简单的a+b (C语言代码)浏览:524 |
找出最长的字符串来 (C语言代码)浏览:1760 |
简单的a+b (C语言代码)浏览:635 |
判定字符位置 (C++代码)浏览:666 |
P1002 (C语言代码)浏览:951 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:598 |