洛谷 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;
}
相关推荐
txzrxz6 小时前
动态规划——背包问题
算法·动态规划
Yingye Zhu(HPXXZYY)6 小时前
洛谷 P15553 [CCPC 2025 哈尔滨站] 液压机
算法
谭欣辰6 小时前
LCS(最长公共子序列)详解
开发语言·c++·算法
m0_629494737 小时前
LeetCode 热题 100-----17.缺失的第一个正数
数据结构·算法·leetcode
Cando学算法7 小时前
鸽笼原理(抽屉原理)
c++·算法·学习方法
Tisfy7 小时前
LeetCode 0796.旋转字符串:暴力模拟
算法·leetcode·题解·模拟·字符串匹配
BlockChain8887 小时前
AI+区块链深度探索:算法与账本的共生时代
人工智能·算法·区块链
生成论实验室7 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第一章 源:不可言说的生成之源
人工智能·科技·算法·生活·创业创新
2zcode7 小时前
基于低光照增强与轻量型CNN道路实时识别算法研究(UI界面+数据集+训练代码)
人工智能·算法·cnn·低光照增强·自动驾驶技术
小雅痞8 小时前
[Java][Leetcode middle] 209. 长度最小的子数组
java·算法·leetcode