CF1132D Stressful Training

Posted cq.tiancx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CF1132D Stressful Training相关的知识,希望对你有一定的参考价值。

题目: CF1132D Stressful Training ,哈哈,我们今天来看一道稍微复杂一点的题嘛,这是选自codeforce上的一道题,好了,我们一起来看看题意吧:

考虑到直接复制题目,或者截屏的方式不是很方便阅读,我就把直接题目链接放下面!
题目传送门: CF1132D Stressful Training

思路:

这道题思路就是采用贪心和二分的思想!!
我们先按照电脑能撑的时间时间从小到大排序,用一个优先队列来维护即可,我们每次判断队头是否符合条件即可,具体的直接看代码吧

我们来看看成功AC的代码吧:

#include<bits/stdc++.h>
using namespace std;
#define ll long long
ll n,k;
ll a[1000010],b[1000010];
ll l=0,r=2e12;
struct node
    ll a,b;
    double c;
    bool operator < (const node &x)const 
        return c>x.c;
    
;
priority_queue<node> q;
int check(ll x)
    while(!q.empty()) q.pop();
    for(int i=1;i<=n;i++)
        if(a[i]*1.0/b[i]<k)
            q.push(a[i],b[i],a[i]*1.0/b[i]);
        
    
    if(q.empty()) return 1; //若队列为空,说明当前x 取大了,因为 所有电脑都能在k分钟内不关机
    for(int i=0;i<k;i++)
        node t = q.top();   q.pop();
        t.a+=x;
        if(t.c<i) return 0;//这台电脑已经没电了
        t.c=t.a*1.0/t.b;
        if(t.a*1.0/t.b<k)
            q.push(t);
        
        if(q.empty()) return 1;

    
    return 1;

int main()
    cin>>n>>k;
    for(int i=1;i<=n;i++) cin>>a[i];
    for(int i=1;i<=n;i++) cin>>b[i];
    while(l<r)
        ll mid=l+r>>1;
        if(check(mid)) r=mid;
        else l=mid+1;
    
    if(l==2e12)
        cout<<-1<<"\\n";
    else cout<<l<<"\\n";
    return 0;


谢谢你的阅读,由于作者水平有限,难免有不足之处,若读者发现问题,还请批评,在留言区留言或者私信告知,我一定会尽快修改的。若各位大佬有什么好的解法,或者有意义的解法都可以在评论区展示额,万分谢谢。
写作不易,望各位老板点点赞,加个关注!

以上是关于CF1132D Stressful Training的主要内容,如果未能解决你的问题,请参考以下文章

CF1132D Stressful Training

Codeforces 1132D - Stressful Training - [二分+贪心+优先队列]

CF 3-6 2级组 D题 STRESSFUL TRAINING 紧张的比赛

Codeforces 1132D(二分答案+堆)

learn to write thesis statement

BP 神经网络