95分求助
查看原帖
95分求助
794484
huanglihuan楼主2024/9/18 19:55
#include <bits/stdc++.h>
#include <cstdio>
#define int long long
#define ull unsigned long long
#define mod 998244353
#define MOD 1000000007
using namespace std;
const int N = 2e6 + 5,maxn = 3e3 + 5;
int a [N],b [N],s [N],f [N];
inline int read ()
{
	int x = 0;
	bool f = 1;
	char c = getchar ();
	while (c < '0' || c > '9') f = (c == '-' ? !f : f),c = getchar ();
	while (c >= '0' && c <= '9') x = (x << 1) + (x << 3) + (c ^ 48),c = getchar ();
	return f ? x : -x;
}
inline void write (int x)
{
	if (x < 0) putchar ('-'),x = -x;
	if (x > 9) write (x / 10);
	putchar (x % 10 + '0');
	return ;
}
signed main ()
{
	int n;
	cin >> n;
	for (int i = 1;i <= n;i ++) s [i] = INT_MAX;
	for (int i = 1;i <= n;i ++) cin >> a [i];
	for (int i = 1;i <= n;i ++) cin >> b [i];
	int cnt = 0,sum = 0;
	for (int i = 1;i <= n;i ++)
	{
		if (b [i] > a [i]) s [i] = b [i] - a [i] + 1,sum ++,f [i] = s [i] - 1;
		else if (b [i] == a [i]) s [i] = 1,f [i] = 0;
		else cnt ++;
	}
	if (cnt > sum) return cout << 0,0;
	int x = sum - cnt + 1;
	sort (s + 1,s + n + 1);
	int ans = 0;
	int t = x;
	for (int i = 1;i <= x && t > 0;i ++)
	{
		ans += s [i];
		t -= 2;
		if (s [i] == 1) t ++;
		if (t == -1 && x != 1) ans --;
	}
	cout << ans;
	return 0;
}

rt.

2024/9/18 19:55
加载中...