给定两个字符串 A
和 B
,现在要将 A
经过若干操作变为 B
,可进行的操作有:
删除–将字符串 A
中的某个字符删除。
插入–在字符串 A
的某个位置插入某个字符。
替换–将字符串 A
中的某个字符替换为另一个字符。
现在请你求出,将 A
变为 B
至少需要进行多少次操作。
输入格式
第一行包含整数 n
,表示字符串 A
的长度。
第二行包含一个长度为 n
的字符串 A
。
第三行包含整数 m
,表示字符串 B
的长度。
第四行包含一个长度为 m
的字符串 B
。
字符串中均只包含大小写字母。
输出格式
输出一个整数,表示最少操作次数。
数据范围
1≤n,m≤1000
输入样例:
10
AGTCTGACGC
11
AGTAAGTAGGC
输出样例:
4
#include <iostream>
#include <algorithm>
using namespace std;
const int N = 1010;
int n, m;
char a[N], b[N];
int f[N][N];
int main ()
{
scanf("%d", &n);
scanf("%s", a + 1);
scanf("%d", &m);
scanf("%s", b + 1);
for(int i = 0; i <= m; i ++ ) f[0][i] = i; // 初始化,只能添加,表示空字符串匹配到b串,有多少个字符就是几步
for(int i = 0; i <= n; i ++ ) f[i][0] = i; // 初始化,表示想把a的前i个字母和b的前0个字符匹配,只能删除,有多少个删除几个
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]) // 第三种情况,如果a[i] 已经等于b[j]了,就不需要加1了
f[i][j] = min(f[i][j], f[i - 1][j - 1]);
else
f[i][j] = min(f[i][j], f[i - 1][j - 1] + 1);
}
printf("%d\n", f[n][m]);
return 0;
}