2020秋招爱奇艺测试开发第一题最少玩游戏的局数

题目描述:假设有N个人要玩游戏,每轮游戏必须选出一个人当裁判,剩下的N-1个人为玩家,现在第i个人要求作为玩家至少进行A轮游戏,那么至少需要进行多少轮游戏才能满足所有人的要求。

主要思想:先找出想要玩游戏次数最多的人,设它想玩m局,则游戏最少要进行m次,再算出所有人要玩游戏的总局数sum,用m*N-sum即为所有人能当裁判的总次数,与游戏局数m进行比较,如果小于游戏局数,则需要继续增加游戏。

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int main()
{
	int n;
	cin >> n;
	if (n < 2)
		return 0;
	vector<int> A;
	for (int i = 0; i < n; i++)
	{
		int tmp;
		cin >> tmp;
		A.push_back(tmp);
	}
	int m = *max_element(A.begin(), A.end());//玩游戏的最大次数
    int sum=0;//总共要玩的局数
	for (int i = 0; i < n; i++)
		sum += A[i];
	while ((n*m-sum)<m)
		m++;
	cout << m << endl;
	return 0;
}

 

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值