蓝桥杯真题讲解:三国游戏(贪心)

一、视频讲解

蓝桥杯真题讲解:三国游戏(贪心)
在这里插入图片描述

二、正解代码

//三国游戏:贪心
#include<bits/stdc++.h>
#define int long long
#define endl '\n'
#define deb(x) cout << #x << " = " << x << '\n';
#define INF 0x3f3f3f3f
using namespace std;
int n;

int cal_ans(vector<int>&a, vector<int>&b, vector<int>&c)
{
	vector<int>tmp(n);
	int sum = 0;

	for(int i = 0; i < n; i ++)
		tmp[i] = a[i] - (b[i] + c[i]);

	sort(tmp.begin(), tmp.end());

	int cnt = 0;
	for(int i = n - 1; i >= 0; i --)
	{
		if(sum + tmp[i] > 0)
		{
			sum += tmp[i];
			cnt ++;
		}
		else
			break;
	}
	return cnt;
}

void solve()
{
	cin >> n;
	vector<int>a(n), b(n), c(n);
	for(int i = 0; i < n; i ++)
		cin >> a[i];

	for(int i = 0; i < n; i ++)
		cin >> b[i];

	for(int i = 0; i < n; i ++)
		cin >> c[i];

	int ans = 0;
	ans = cal_ans(a, b, c);//x赢


	ans = max(ans, cal_ans(b, a, c));//y赢

	ans = max(ans, cal_ans(c, a, b));//z赢
	
	if(ans)
		cout << ans << endl;
	else
		cout << -1 << endl;
}

signed main()
{
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	int t;
	t = 1;
	//cin >> t;
	while(t--)
	solve();
}
Logo

有“AI”的1024 = 2048,欢迎大家加入2048 AI社区

更多推荐