【JZOJ4809】【NOIP2016提高A组五校联考1】挖金矿
题目描述
输入
输出
样例输入
4 3 
4 3 3 
5 1 6 
2 6 1 
3 2 9
样例输出
4.4286
数据范围
样例解释
解法
二分答案。
对于答案ans,如果每一列的最大贡献之和大于0,则ans合法; 
每一列的最大贡献=max(a[1..i]−i∗ans),其中1<=i<=m。
代码
#include<iostream>
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<algorithm>
#define ll long long
#define ln(x,y) ll(log(x)/log(y))
#define sqr(x) ((x)*(x))
using namespace std;
const char* fin="aP1.in";
const char* fout="aP1.out";
const ll inf=0x7fffffff;
const ll maxn=100007;
ll n,m,i,j,k,tot;
double ans,l,r,mid;
ll a[maxn];
bool judge(double v){
    int i,j,k;
    double tmp,tmd,maxx,sum=0;
    for (i=1;i<=n;i++){
        tmp=tmd=maxx=0;
        bool bz=false;
        for (j=1;j<=m;j++){
            tmp+=a[(i-1)*m+j];
            tmd+=v;
            if (!bz || maxx<tmp-tmd){
                bz=true;
                maxx=tmp-tmd;
            }
        }
        sum+=maxx;
    }
    return sum>=0;
}
int main(){
    scanf("%d%d",&n,&m);
    tot=n*m;
    for (i=1;i<=tot;i++){
        scanf("%d",&a[i]);
    }
    l=0;
    r=1000000000;
    while (r-l>1e-6){
        mid=(l+r)/2;
        if (judge(mid)) l=mid;
        else r=mid;
    }
    printf("%.4lf",l);
    return 0;
}
启发
求平均数可以使用二分把问题转化为判定性问题。
【JZOJ4809】【NOIP2016提高A组五校联考1】挖金矿的更多相关文章
- NOIP2016提高A组五校联考4总结
		
坑爹的第一题,我居然想了足足3个小时,而且还不确定是否正确. 于是,我就在这种情况下心惊胆跳的打了,好在ac了,否则就爆零了. 第二题,树形dp,本来差点就想到了正解,结果时间不够,没打完. 第三题, ...
 - 【NOIP2016提高A组五校联考4】square
		
题目 分析 首先,设\(f_{i,j}\)表示最大的以(i,j)为左下角的正方形的边长. 转移显然,\(f_{i,j}=\max(f_{i-1,j},f_{i,j-1},f_{i-1,j-1})+1\ ...
 - 【NOIP2016提高A组五校联考4】label
		
题目 题目 20%算法 设\(f_{i,j}\)表示第i个节点选了j这个权值的方案数. 显然转移方程为,\[f_{i,j}=\Pi_{v=son(i)}(\sum_{k=1}^{j-k}f_{v,k} ...
 - 【NOIP2016提高A组五校联考4】ksum
		
题目 分析 发现,当子段[l,r]被取了出来,那么[l-1,r].[l,r+1]一定也被取了出来. 那么,首先将[1,n]放入大顶堆,每次将堆顶的子段[l,r]取出来,因为它是堆顶,所以一定是最大的子 ...
 - NOIP2016提高A组五校联考3总结
		
第一题,本来一开始就想到了数位dp,结果脑残地打了十几个转移方程,总是调试不出来,一气之下放弃了. 调第一题几乎调了整节比赛,第二第三都没它. 第二题连边找联通块. 第三题题解都打了三页,看都不想看. ...
 - 【NOIP2016提高A组五校联考2】tree
		
题目 给一棵n 个结点的有根树,结点由1 到n 标号,根结点的标号为1.每个结点上有一个物品,第i 个结点上的物品价值为vi. 你需要从所有结点中选出若干个结点,使得对于任意一个被选中的结点,其到根的 ...
 - 【NOIP2016提高A组五校联考2】running
		
题目 小胡同学是个热爱运动的好孩子. 每天晚上,小胡都会去操场上跑步,学校的操场可以看成一个由n个格子排成的一个环形,格子按照顺时针顺序从0 到n- 1 标号. 小胡观察到有m 个同学在跑步,最开始每 ...
 - 【NOIP2016提高A组五校联考2】string
		
题目 给出一个长度为n, 由小写英文字母组成的字符串S, 求在所有由小写英文字母组成且长度为n 且恰好有k 位与S 不同的字符串中,给定字符串T 按照字典序排在第几位. 由于答案可能很大,模10^9 ...
 - NOIP2016提高A组五校联考2总结
		
第一题用组合数各种乱搞,其恶心程度不一般.搞了很久才调对,比赛上出了一点bug,只拿了30分. 第二题我乱搞得出个错误的结论,本来自信满满60分,结果爆零了. 第三题,树形dp,在一开始的时候想到了, ...
 
随机推荐
- [HEOI2016/TJOI2016]排序 线段树+二分
			
[HEOI2016/TJOI2016]排序 内存限制:256 MiB 时间限制:6000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述 在2016年,佳媛姐姐喜欢上了数字序列.因而 ...
 - HZOI2019 超级树 dp
			
题面:https://www.cnblogs.com/Juve/articles/11207540.html(密码)————————————————>>> 题解: 官方题解: 考虑d ...
 - 【arc075f】AtCoder Regular Contest 075 F - Mirrored
			
题意 给定一个数x,问有多少个正整数y,使得rev(y)-y==x 其中rev(x)表示x按位翻转之后得到的数. x<=1e9 做法 首先通过打表发现,这个答案不会很大. 这就说明解相当地松弛. ...
 - 关于Cesium 官方教程
			
最近一直在准备第一次QQ群的Cesium基础培训公开课,虽说使用Cesium也有段日子了,但是要说对Cesium了解有多深,还真不一定.原因是一直以来我都是用哪里学哪里.基于多年开发三维数字地球的底层 ...
 - mysql基本笔记之一
			
1.创建数据库 CREATE DATABASE admin 2.查看数据库 SHOW DATABASES 3.使用数据库 USE admin 4.创建user表 CREATE TABLE user V ...
 - Spring Cloud Eureka集群配置及注意事项(Greenwich版本)
			
Spring Cloud Eureka集群配置及注意事项(Greenwich版本) 一·概述 Spring Cloud Netflix Eureka 是一个提供服务注册与发现的套件.服务提供者只需要将 ...
 - 访问hbase的内部大致流程
			
hbase 访问表过程.Client(客户端)----->访问ZK(拿到meta表的region位置)----->访问meta 表的region------>拿到user表的regi ...
 - finger 工具:用来查询用户信息,侧重用户家目录、登录SHELL等
			
finger 工具侧重于用户信息的查询:查询的内容包括用户名(也被称为登录名Login),家目录,用户真实的名字(Name)... ... 办公地址.办公电话:也包括登录终端.写状态.空闭时间等: 我 ...
 - 入门servlet:request获取请求体数据
			
@WebServlet("/RequestDemo5") public class RequestDemo5 extends HttpServlet { protected voi ...
 - golang 程序 在linux 出现 段错误
			
刚做的 golang 程序 发布到linux 竟然出现 段错误 原因是 内核版本过低,请升级内核