题目描述

Farmer John’s arch-nemesis, Farmer Paul, has decided to sabotage Farmer John’s milking equipment!

The milking equipment consists of a row of N (3 <= N <= 100,000) milking machines, where the ith machine produces M_i units of milk (1 <= M_i <= 10,000). Farmer Paul plans to disconnect a contiguous block of these machines – from the ith machine up to the jth machine (2 <= i <= j <= N-1); note that Farmer Paul does not want to disconnect either the first or the last machine, since this will make his plot too easy to discover. Farmer Paul’s goal is to minimize the average milk production of the remaining machines. Farmer Paul plans to remove at least 1 cow, even if it would be better for him to avoid sabotage entirely.

Fortunately, Farmer John has learned of Farmer Paul’s evil plot, and he is wondering how bad his milk production will suffer if the plot succeeds. Please help Farmer John figure out the minimum average milk production of the remaining machines if Farmer Paul does succeed.

农夫约翰的头号敌人保罗决定破坏农民约翰的挤奶设备。挤奶设备排成一行,共N(3<= N <=100000)台挤奶机,其中第i个台挤奶机生产M_i单位(1 <= M_i<=10,000)的牛奶。

保罗计划切断一段连续的挤奶机,从第i台挤奶机到第j台挤奶机(2<= i<= j<= N-1)。注意,他不希望断开第一台或最后一台挤奶机,因为这将会使他的计划太容易被发现。保罗的目标是让其余机器的平均产奶量最小。保罗计划除去至少1台挤奶机。

请计算剩余机器的最小平均产奶量。
输入输出格式
输入格式:

第 1 行:一个整数 N。

第 2 到 N+1 行:第 i+1 行包含一个整数 M_i。

输出格式:

第 1 行: 一个实数, 表示平均牛奶产量的最小值, 保留三位小数 (四舍五入)。

输入输出样例
输入样例#1:

5
5
1
7
8
2

输出样例#1:

2.667

说明

【样例说明】

移去 7 和 8,剩下 5, 1, 2,平均值为 8/3。

【数据规模和约定】

对于 30%的数据,N <= 1,000。

对于 50%的数据,N <= 10,000。

对于 100%的数据,3 <= N <= 100,000,1 <= M_i <= 10,000。

这是从国外大牛看过来的:
这道题答案满足单调性,满足二分的性质,我们不妨设从i移到j,则如果满足答案x,则有以下不等式:

所以如果存在x满足不等式,对于在j之前的(S[i-1]-x*(i-1))取一个最小的,然后判断。

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 100010
using namespace std;
int n,a[N],s[N];
bool check(double x){double minv=s[1]-x*1;for (int i=2;i<n;i++){if (s[n]-x*n-(s[i]-x*i)+minv <=0) return 1;minv=s[i]-x*i <minv?s[i]-x*i :minv;}return 0;
}
int main(){scanf("%d",&n);s[0]=0;for (int i=1;i<=n;i++) scanf("%d",&a[i]),s[i]=s[i-1]+a[i];double l=0,r=N; while (r-l>1e-5){double mid=(l+r)/2;if (check(mid)) r=mid;else l=mid;}printf("%.3lf",l);return 0;
}

USACO2014MAR 破坏Sabotage相关推荐

  1. P2115 [USACO14MAR]破坏Sabotage

    P2115 [USACO14MAR]破坏Sabotage 题目描述 Farmer John's arch-nemesis, Farmer Paul, has decided to sabotage F ...

  2. [USACO14MAR]破坏Sabotage

    题目链接:[USACO14MAR]破坏Sabotage 首先肯定二分最小值. 然后找到是否存在一个前缀min和后缀min之和小于0即可. AC代码: #pragma GCC optimize(&quo ...

  3. USACO Sabotage

    洛谷 P2115 [USACO14MAR]破坏Sabotage https://www.luogu.org/problem/P2115 JDOJ 2418: USACO 2014 Mar Gold 2 ...

  4. 区块链关键技术研究进展

    摘要 区块链是一种由多方共同维护,使用密码学保证传输和访问安全,能够实现数据一致存储.难以篡改.防止抵赖的记账技术,也称为分布式账本技术.近年来,区块链技术的发展对社会产生了重要的影响.本文介绍近年来 ...

  5. 社会工程常见攻击方式

    社会工程学(Social Engineering)是一种通过对受害者心理弱点.本能反应.好奇心.信任.贪 婪等心理陷阱进行诸如欺骗.伤害等危害手段.社会工程学攻击在近年来的一些网络入侵事件中起到了很大 ...

  6. 社会工程学攻击经典方法总结

    社会工程学(Social Engineering)是一种通过对受害者心理弱点.本能反应.好奇心.信任.贪婪等心理陷阱进行诸如欺骗.伤害等危害手段.社会工程学攻击在近年来的一些网络安全事件中起到了很大的 ...

  7. [USACO14MAR]Sabotage G

    [USACO14MAR]Sabotage G 题目描述 Farmer John's arch-nemesis, Farmer Paul, has decided to sabotage Farmer ...

  8. 二分答案 [Usaco2014 Mar]Sabotage

    问题 L: [Usaco2014 Mar]Sabotage 时间限制: 1 Sec 内存限制: 128 MB 题目描述 Farmer John"s arch-nemesis, Farmer ...

  9. [Usaco2014 Mar]Sabotage

    [Usaco2014 Mar]Sabotage 题目 Farmer John"s arch-nemesis, Farmer Paul, has decided to sabotage Far ...

最新文章

  1. cwntos新建目录挂载磁盘_Ubuntu系统下不同硬盘分区与挂载
  2. mysql parameters_MySqlCommand Command.Parameters.Add已过时
  3. VC6解决托盘菜单不消失
  4. C++为什么要学指针?
  5. SQL 查找是否存在,别再 COUNT 了,很耗费时间的
  6. 深度学习:在图像上找到手势_使用深度学习的人类情绪和手势检测器:第2部分
  7. C++:fseek( FILE *stream, long offset, int origin )
  8. iOS 在视图中调整按钮距离边框的位置
  9. 阿里云盾证书服务助力博客装逼成功
  10. 熟练使用 Elastic Job系列之作业分片策略(五)
  11. c语言逻辑推理题大全,C语言逻辑推理例题(附答案)
  12. 初次使用dcm4che-tool-findscu做查询
  13. win7耳机插前面没声音_win7电脑音箱没声音如何解决 win7电脑音箱没声音解决方式【图解】...
  14. 微信聊天记录迁移及故障修复
  15. sketch清理缓存文件,sketch清理运行内存工具
  16. 扫描二维码启动微信打开特定页面
  17. ping github.com 请求超时/丢包率为100% || Windows “您没有权限在此位置保存文件”(已解决)
  18. TensorFlow笔记(7) 多神经元分类
  19. Android开发实例家庭理财通,基于安卓的家庭理财通
  20. 【iot-manager】(1)IOT商业化和未来竞争、淘汰还在继续,需要折腾一个开源IOT系统,参考Rancher开源Octopus:IoT设备管理系统做一个物联网管理系统

热门文章

  1. 二维码生成器源代码之帮你做微信小程序
  2. 乐观锁和悲观锁全面总结及实际应用介绍
  3. CorelDRAW VBA - 打开选择文件夹对话框
  4. java添加例外站点用途_JAVA控制台添加例外站点,应用程序已被安全设置阻止
  5. 移动端 —— 微信二维码生成、授权登陆,展示用户信息页
  6. 软件驱动安装在docker_nvidia-docker2配置与NVIDIA驱动安装
  7. [Python]常用国内pip镜像源合集
  8. CSS 的持续悲剧:2023 年 CSS Day 的思考
  9. 百度apollo——启动脚本
  10. 同余方程 ax≡1(mod b) POJ 1061 青蛙的约会