洛谷 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;
}
相关推荐
嘉陵妹妹29 分钟前
深度优先算法学习
学习·算法·深度优先
GalaxyPokemon1 小时前
LeetCode - 53. 最大子数组和
算法·leetcode·职场和发展
hn小菜鸡2 小时前
LeetCode 1356.根据数字二进制下1的数目排序
数据结构·算法·leetcode
zhuiQiuMX2 小时前
分享今天做的力扣SQL题
sql·算法·leetcode
music&movie3 小时前
算法工程师认知水平要求总结
人工智能·算法
laocui14 小时前
Σ∆ 数字滤波
人工智能·算法
yzx9910134 小时前
Linux 系统中的算法技巧与性能优化
linux·算法·性能优化
全栈凯哥4 小时前
Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解
java·算法·leetcode·链表
全栈凯哥4 小时前
Java详解LeetCode 热题 100(27):LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)详解
java·算法·leetcode·链表
SuperCandyXu5 小时前
leetcode2368. 受限条件下可到达节点的数目-medium
数据结构·c++·算法·leetcode