• BZOJ_3477_[Usaco2014 Mar]Sabotage_二分答案


    BZOJ_3477_[Usaco2014 Mar]Sabotage_二分答案

    题意:

    约翰的牧场里有 N 台机器,第 i 台机器的工作能力为 Ai。保罗阴谋破坏一些机器,使得约翰的工作效率变低。保罗可以任意选取一段编号连续的机器,使它们停止工作。但这样的破次,而且保罗无法破坏第一台或最后一台机器。请问他该破坏哪些机器才能让剩下机器的工作效率的平均数最小?为了显示存在感,保罗至少必须破坏一台机器。

    分析:

    二分出答案k,将a[i]-k,求出2到n-1最大子段和mx。用sum-mx既是剩下的前一段后一段的和。如果小于0则是合法的。

    代码:

    #include <stdio.h>
    #include <string.h>
    #include <algorithm>
    using namespace std;
    #define N 100050
    #define du double 
    int a[N],n;
    du sum;
    bool check(du x)
    {
        du ans=-100000,f=-100000;
        for(int i=2;i<n;i++)
        {
            du now=a[i]-x;
            f=max(now,f+now);
            ans=max(ans,f);
        }
        if(sum-x*n-ans<=0)return 1;
        return 0;
    }
    int main()
    {
        scanf("%d",&n);
        for(int i=1;i<=n;i++)
        {
            scanf("%d",&a[i]);
            sum+=a[i];
        }
        du l=0,r=1000000;
        for(int i=1;i<=60;i++)
        {
            du mid=(l+r)*0.5;
            if(check(mid))r=mid;
            else l=mid; 
        }
        printf("%.3lf",l);
    }
    
  • 相关阅读:
    Codeforces 525C Om Nom and Candies 枚举 + 复杂度分析
    Codeforces 526B Om Nom and Dark Park 树形dp
    Codeforces 526A King of Thieves 枚举
    Regionals 2014 Asia
    Regionals 2014 Asia
    access数据库和sqlsever数据库sql语句的布尔值boolean的写法
    取消阴影行
    引用其他单元的2种方法
    选中阴影行
    全选
  • 原文地址:https://www.cnblogs.com/suika/p/8436678.html
Copyright © 2020-2023  润新知