洛谷 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;
}
相关推荐
大大dxy大大7 分钟前
机器学习-KNN算法示例
人工智能·算法·机器学习
关于不上作者榜就原神启动那件事1 小时前
模拟算法乒乓球
开发语言·c++·算法
Bug退退退1231 小时前
ArrayList 与 LinkedList 的区别
java·数据结构·算法
88号技师2 小时前
2025年7月一区SCI优化算法-Logistic-Gauss Circle optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
一个不知名程序员www3 小时前
算法学习入门---二分查找(C++)
c++·算法
2301_807997383 小时前
代码随想录-day26
数据结构·c++·算法·leetcode
闭着眼睛学算法3 小时前
【双机位A卷】华为OD笔试之【排序】双机位A-银行插队【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
TL滕3 小时前
从0开始学算法——第一天(认识算法)
数据结构·笔记·学习·算法
小欣加油3 小时前
leetcode 3318 计算子数组的x-sum I
c++·算法·leetcode·职场和发展
love is sour4 小时前
聚类(Clustering)详解:让机器自己发现数据结构
算法·支持向量机·聚类