首页 > 其他 > 详细

[CodeForces1492C] Maximum Width

时间:2021-02-28 10:50:25      阅读:42      评论:0      收藏:0      [点我收藏+]

description:
There are two strings \(a\), \(b\) with the length \(n\), and \(m\).
Find the Array <\(p_1, p_2, ..., p_m>\), such that \(a_{p_i}= b_i\), \(\max\{p_{i+1}-p_i\}\) is max.
solution:
Let array left mark the left-first find \(p_i\), right mark the right-first find \(p_i\).
The answer is :

\(\max_{i=1}^{m-1}\{right[i+1]- left[i]\}\)
code:

#include<cstdio>
const int N = 2e5 + 1;
const int inf = -1e9;
char a[N], b[N];
int left[N], right[N];
int main() {
	int n, m;
	scanf("%d%d%s%s", &n, &m, a, b);
	int last = -1;
	for (int i = 0; i < m; ++i) {
		while (a[++last] != b[i]);
		left[i] = last;
	}
	last = n;
	for (int i = m - 1; i >= 0; --i) {
		while (a[--last] != b[i]);
		right[i] = last;
	}
	int ans = inf;
	for (int i = 1; i < m; ++i) {
		int cur = right[i] - left[i - 1];
		if (cur > ans)ans = cur;
	}
	printf("%d\n", ans);
}

[CodeForces1492C] Maximum Width

原文:https://www.cnblogs.com/dwt2021/p/14458106.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!