题意:满足n个人,每个人想玩的游戏次数。输出最小(m)的游戏次数。
分析:把每个的要玩的游戏次数看成要得到的物体,而每次需要有一个人不能得到。即有n*m-sum>=m,m>=sum/(n-1);
而m必定大于或等于最大想玩的人的次数:故m>=max(a1,a2...an);
#include<iostream>
#include<cstdio>
#include<cstring>
typedef __int64 LL;
using namespace std ;
LL a[100005];
int main()
{
int n;
LL sum,m,ans;
while(scanf("%d",&n)!=EOF){
m=sum=0;
for(int i=0;i<n;i++){
scanf("%I64d",&a[i]);
sum+=a[i];
m=max(a[i],m);
}
if(sum%(n-1)) ans=sum/(n-1)+1;
else ans=sum/(n-1);
printf("%I64d\n",max(ans,m));
}
return 0 ;
}