洛谷 P8703 [蓝桥杯 2019 国 B] 最优包含(dp)

题目链接

https://www.luogu.com.cn/problem/P8703

思路

令 n n n表示 S S S的长度, m m m表示 T T T的长度。

d p [ i ] [ j ] dp[i][j] dp[i][j]表示使得 S S S的前 i i i个字符能够完全包含 T T T的前 j j j个字符所需要修改的最少字符数。

当 S [ i ] = T [ j ] S[i]=T[j] S[i]=T[j]时, d p [ i ] [ j ] = d p [ i − 1 ] [ j − 1 ] dp[i][j] = dp[i-1][j-1] dp[i][j]=dp[i−1][j−1]。

当 S [ i ] ≠ T [ j ] S[i] \ne T[j] S[i]=T[j]时, d p [ i ] [ j ] = m i n ( d p [ i − 1 ] [ j − 1 ] + 1 , d p [ i − 1 ] [ j ] ) dp[i][j] = min(dp[i-1][j-1]+1,dp[i-1][j]) dp[i][j]=min(dp[i−1][j−1]+1,dp[i−1][j]),其中 d p [ i − 1 ] [ j − 1 ] dp[i-1][j-1] dp[i−1][j−1]表示 S S S的第 i i i个字符与 T T T的第 j j j个字符匹配, d p [ i − 1 ] [ j ] dp[i-1][j] dp[i−1][j]表示 T T T的第 j j j个字符与 S S S的前 i − 1 i-1 i−1个字符中的一个匹配。

最后的答案为: d p [ n ] [ m ] dp[n][m] dp[n][m]。

时间复杂度: O ( n × m ) O(n \times m) O(n×m)。

代码

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

#define int long long
#define double long double

typedef long long i64;
typedef unsigned long long u64;
typedef pair<int, int> pii;

const int N = 1e3 + 5, M = 1e6 + 5;
const int mod = 1e9 + 7;
const int inf = 0x3f3f3f3f3f3f3f3f;

std::mt19937 rnd(time(0));

string s, t;
int dp[N][N];
void solve(int test_case)
{
	cin >> s >> t;
	int n = s.size(), m = t.size();
	s = "#" + s, t = "#" + t;
	memset(dp, inf, sizeof dp);
	for (int i = 0; i <= n; i++)
		dp[i][0] = 0;
	for (int i = 1; i <= n; i++)
	{
		for (int j = 1; j <= m; j++)
		{
			if (s[i] == t[j])
			{
				dp[i][j] = dp[i - 1][j - 1];
			}
			else
			{
				dp[i][j] = min(dp[i - 1][j - 1] + 1, dp[i - 1][j]);
			}
		}
	}
	cout << dp[n][m] << endl;
}

signed main()
{
	ios::sync_with_stdio(false);
	cin.tie(0), cout.tie(0);
	int test = 1;
	// cin >> test;
	for (int i = 1; i <= test; i++)
	{
		solve(i);
	}
	return 0;
}
相关推荐
一招定胜负16 小时前
机器学习+深度学习经典算法面试复习指南
深度学习·算法·机器学习
皮卡狮16 小时前
高阶数据结构:AVL树
数据结构·算法
天若有情67316 小时前
通用个性化推荐核心架构思路:从视频到电商的跨场景落地实践
人工智能·算法·架构·推流·个性化推荐·猜你喜欢
s090713616 小时前
【声纳成像】基于滑动子孔径与加权拼接的条带式多子阵SAS连续成像(MATLAB仿真)
开发语言·算法·matlab·合成孔径声呐·后向投影算法·条带拼接
jay神16 小时前
基于YOLOv8的钢材表面缺陷检测系统
人工智能·算法·yolo·目标检测·计算机视觉
Accerlator17 小时前
2026年3月21日刷题
算法
2401_8916558117 小时前
此电脑网络位置异常的AD域排错指南的技术文章大纲
开发语言·python·算法
DLGXY17 小时前
STM32(二十七)——独立看门狗&窗口看门狗
stm32·嵌入式硬件·算法
不要秃头的小孩17 小时前
50. 随机数排序
数据结构·python·算法
tankeven17 小时前
HJ139 小红的01子序列计数(hard)
c++·算法