【题解】AT3909

思路

看到这道题,我首先想到求到数组 \(a\) 的和 \(s1\),和数组 \(b\) 的和 \(s2\)

如果 \(s1 > s2\), 那就不可能让两个数组完全相同。

但是样例就已经把这种方法否定了。

但是我们不难发现:

  • \(a\) 数组中的这个值小于 \(b\) 数组中的这个值,则增加 \(a\) 数组中的数字。如果要让他们相等的话,需要 \(\frac{b_i-a_i}{2}\) 次。

  • \(a\) 数组中的这个值大于 \(b\) 数组中的这个值,加 \(a_i-b_i\)

我们只需要从 \(1\)\(n\) 跑一遍即可。

Code

#include <cstdio>
#define int long long
const int MAXN = 1e5 + 10;
int n, s1, s2;
int a[MAXN], b[MAXN];
signed main() {
	scanf("%d", &n);
	for (int i = 1; i <= n; i++)
		scanf("%lld", &a[i]);
	for (int i = 1; i <= n; i++)
		scanf("%lld", &b[i]);
	for (int i = 1; i <= n; i++) {
		if (a[i] > b[i])
			s1 += (a[i] - b[i]);
		if (a[i] < b[i])
			s2 += (b[i] - a[i]) / 2;
	}//
	if (s1 <= s2)
		printf("Yes\n");
	else
		printf("No\n");
}
posted @ 2022-07-27 21:25  zhou_ziyi  阅读(19)  评论(0编辑  收藏  举报