牛客题霸CodeForces(Div 1) 348AMafia题解

按照模拟思路,我们每次操作要考虑每一回合哪些n-1个人要进行游戏 。

但是我们不如逆向思维,每一回合我们都只需要一个观察者,那么我们此时最多可以玩多少回合呢?

要使回合数最多,那么就是让这个人玩够了就去一直当裁判

所以最多回合数就是(当前要玩的回合数-第i个人想要玩的局数)

最后如果这个最多回合数大于等于当前要进行的回合数,就可以保证每一回合都有人当裁判,这个回合数也就可行。

代码

#include<iostream>
#include<algorithm>
using namespace std;
long long n;
long long gamers[100005];
bool check(long long x){
    long long sum=0;
    for(int i=0;i<n;i++){
        sum+=x-gamers[i];
    }
    return sum>=x;
}
int main(void){
    ios::sync_with_stdio(false);
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>gamers[i];
    }
    sort(gamers,gamers+n);
    long long left=gamers[n-1],right=0x3f3f3f3f3f3f;
    while(left<=right){
        long long mid = (left+right)>>1;
        if(check(mid)){
            right=mid-1;
        }
        else
        {
            left=mid+1;
        }
    }
    cout<<left<<endl;
    return 0;
}
全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务