洛谷 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;
}
相关推荐
sin_hielo5 小时前
leetcode 110
数据结构·算法·leetcode
整得咔咔响5 小时前
贝尔曼最优公式(BOE)
人工智能·算法·机器学习
日拱一卒——功不唐捐5 小时前
字符串匹配:暴力法和KMP算法(C语言)
c语言·算法
renke33645 小时前
Flutter for OpenHarmony:数字涟漪 - 基于扩散算法的逻辑解谜游戏设计与实现
算法·flutter·游戏
AI科技星5 小时前
从ZUFT光速螺旋运动求导推出自然常数e
服务器·人工智能·线性代数·算法·矩阵
老鼠只爱大米5 小时前
LeetCode经典算法面试题 #78:子集(回溯法、迭代法、动态规划等多种实现方案详细解析)
算法·leetcode·动态规划·回溯·位运算·子集
执着2595 小时前
力扣hot100 - 199、二叉树的右视图
数据结构·算法·leetcode
I_LPL5 小时前
day21 代码随想录算法训练营 二叉树专题8
算法·二叉树·递归
可编程芯片开发5 小时前
基于PSO粒子群优化PI控制器的无刷直流电机最优控制系统simulink建模与仿真
人工智能·算法·simulink·pso·pi控制器·pso-pi
cpp_25015 小时前
P8448 [LSOT-1] 暴龙的土豆
数据结构·c++·算法·题解·洛谷