697: Edit Distance

我们定义 dp[i][j] 为将字符串 A[0..i-1] 转换为 B[0..j-1] 的最小操作数

状态转移

通过动态规划的思想,我们可以使用 状态转移方程 来计算 dp[i][j]。具体来说,dp[i][j] 的值可以由以下几种操作得到:

  1. 如果 A[i-1] == B[j-1]

    • 如果 A[i-1]B[j-1] 相同,说明不需要对这两个字符做任何操作,那么我们只需从 dp[i-1][j-1] 继承结果:

    dp[i][j] = dp[i-1][j-1]

  2. 如果 A[i-1] != B[j-1]

    • 删除操作 :从 A[0..i-1] 删除一个字符,使其变为 A[0..i-2],即 dp[i][j] = dp[i-1][j] + 1
    • 插入操作 :从 B[0..j-1] 插入一个字符,变为 B[0..j-2],即 dp[i][j] = dp[i][j-1] + 1
    • 替换操作 :将 A[i-1] 替换为 B[j-1],即 dp[i][j] = dp[i-1][j-1] + 1
  3. 选择最小操作数

    • 由于我们需要最少的操作数,因此 dp[i][j] 是以上三种操作中最小的操作数。
边界条件

在动态规划的过程中,我们需要先初始化边界条件:

  • dp[i][0] :将 A[0..i-1] 转换为空字符串,需要 i 次删除操作:

    dp[i][0] = i

  • dp[0][j] :将空字符串转换为 B[0..j-1],需要 j 次插入操作:

    dp[0][j] = j

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
const int N = 1e4+4;
int dp[N][N];
int main() {
	string a, b;
	cin >> a >> b;
	int m = a.size();
	int n = b.size();
	for (int i = 0; i <= m; i++) {
		dp[i][0] = i;
	}
	for (int j = 0; j <= n; j++) {
		dp[0][j] = j;
	}

	for (int i = 1; i <= m; i++) {
		for (int j = 1; j <= n; j++) {
			if (a[i - 1] == b[j - 1]) {
				dp[i][j] = dp[i - 1][j - 1];
			}
			else {
				dp[i][j] = min({
					dp[i - 1][j],dp[i][j - 1],dp[i - 1][j - 1]
					}) + 1;
			}
		}
	}
	cout << dp[m][n] << endl;
	return 0;
}
相关推荐
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之字符串 --【子串查找】:[NOIP 2009 提高组] 潜伏者
c++·字符串·csp·高频考点·信奥赛·子串查找·潜伏者
初願致夕霞9 小时前
基于系统调用的Linux网络编程——UDP与TCP
linux·网络·c++·tcp/ip·udp
小小de风呀11 小时前
de风——【从零开始学C++】(五):内存管理
开发语言·c++
CHANG_THE_WORLD12 小时前
C语言中的 %*s 和 %.*s 和C++的字符串格式化输出
c语言·c++·c#
螺丝钉的扭矩一瞬间产生高能蛋白13 小时前
QT的C++接口基础用法
c++·qt·嵌入式软件·嵌入式linux·linux应用
智者知已应修善业14 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
智者知已应修善业14 小时前
【51单片机如何让LED灯从一亮到八,再从八亮到一】2023-10-13
c++·经验分享·笔记·算法·51单片机
qeen8714 小时前
【数据结构】二叉树相关经典函数C语言实现
c语言·数据结构·c++·笔记·学习·算法·二叉树
良木生香14 小时前
【C++初阶】STL——List从入门到应用完全指南(1)
开发语言·数据结构·c++·程序人生·算法·蓝桥杯·学习方法