[洛谷P1404] 平均数
洛谷题目链接:平均数
题目描述
给一个长度为n的数列,我们需要找出该数列的一个子串,使得子串平均数最大化,并且子串长度>=m。
输入输出格式
输入格式:
N+1行,
第一行两个整数n和m
接下来n行,每行一个整数a[i],表示序列第i个数字
输出格式:
一个整数,他是最大平均数的1000倍,如果末尾有小数,直接舍去,不要用四舍五入求整。
输入输出样例
输入样例#1:
10 6
6
4
2
10
3
8
5
9
4
1
输出样例#1:
6500
说明
【数据范围】
60% M<=N<=10000
100% M<=N<=100000 0<=a[i]<=2000
一句话题意: 给出一个长度为\(n\)的序列,要求出其中一个长度大于等于\(m\)的子段使得这个子段的平均值最大.
题解: 首先这个平均数是具有单调性的,如果某一个值可以作为最大平均值,那么比它大的值也有可能是平均值,如果某个值经过验证无法成为平均值,那么比这个大的就肯定无法成为平均值.所以可以想到二分.
但是如果要二分的话要怎么验证呢?
我们可以在每次\(check\)中,先将序列中的值都减去二分出来的\(mid\),然后对序列中的值求一个前缀和,再对这个前缀和统计一个最小值.我们用\(S_i\)表示1~ i的前缀和,\(Mn_i\)表示1~i中前缀和的最小值.
这样的话,我们在枚举一个长度大于等于\(m\)的区间\([i,j](j∈[i+m-1,n])\)的时候,这个区间内的和就是\(S_j-S_{i-1}\),但是因为我们已经将这个序列的每个元素都减去了\(mid\),也就相当于这个区间这个区间的平均值减去了\(mid\).这时如果区间和是大于等于0的,也就是说这个区间在没有减去\(mid\)之前它的平均值是大于等于\(mid\)的.
然后通过我们记录的\(Mn\),可以得到1~ i的前缀和的最小值,这样就可以通过固定一个右端点的方法,记录下向左扩展得到最大区间和.如果区间和是正数,那么除以它的个数后还是正数,则存在一个子段使得这个区间的平均值大于等于\(mid\).
然后最后算出来的结果最好是加一个较小的数,因为转int向下取整,有可能会使答案变小,加一个较小的数会被向下取整忽略掉.
#include<bits/stdc++.h>
using namespace std;
const int N=100000+5;
const double eps=1e-5;
const int inf=2147483647;
int n, m, ans = 0;
double a[N], b[N], s[N], mn[N];
int gi(){
int ans = 0, f = 1; char i = getchar();
while(i<'0' || i>'9'){ if(i == '-') f = -1; i = getchar(); }
while(i>='0' && i<='9') ans = ans*10+i-'0', i = getchar();
return ans * f;
}
bool check1(double mid){
memcpy(b, a, sizeof(b));
for(int i=1;i<=n;i++) b[i] -= mid, s[i] = s[i-1]+b[i], mn[i] = min(mn[i-1], s[i]);
for(int i=m;i<=n;i++)
if(s[i]-mn[i-m] > 0) return true;
return false;
}
int main(){
//freopen("cowfnc.in", "r", stdin);
//freopen("cowfnc.out", "w", stdout);
n = gi(), m = gi(); mn[0] = 0;
for(int i=1;i<=n;i++) a[i] = gi();
double l = 0, r = inf, res;
while(r-l > eps){
double mid = (l+r)/2;
if(check1(mid)) res = mid, l = mid;
else r = mid;
}
ans = (res+2e-4)*1000;
cout << ans << endl;
return 0;
}
ps:鸡哥巨佬要我把讲解都删掉,然后膜他
Brave_Cattle sto yyj orz Brave_Cattle
[洛谷P1404] 平均数的更多相关文章
- 洛谷 P1404 平均数
P1404 平均数 题目描述 给一个长度为n的数列,我们需要找出该数列的一个子串,使得子串平均数最大化,并且子串长度>=m. 输入输出格式 输入格式: N+1行, 第一行两个整数n和m 接下来n ...
- 洛谷——P1404 平均数
P1404 平均数 题目描述 给一个长度为n的数列,我们需要找出该数列的一个子串,使得子串平均数最大化,并且子串长度>=m. 前缀和+二分答案 #include<iostream> ...
- 洛谷P1404 平均数 [01分数规划,二分答案]
题目传送门 平均数 题目描述 给一个长度为n的数列,我们需要找出该数列的一个子串,使得子串平均数最大化,并且子串长度>=m. 输入输出格式 输入格式: N+1行, 第一行两个整数n和m 接下来n ...
- 洛谷P1471 方差
蒟蒻HansBug在一本数学书里面发现了一个神奇的数列,包含N个实数.他想算算这个数列的平均数和方差. ——by 洛谷; http://www.luogu.org/problem/show?pid=1 ...
- 洛谷 P1471 方差
洛谷 P1471 方差 题目背景 滚粗了的HansBug在收拾旧数学书,然而他发现了什么奇妙的东西. 题目描述 蒟蒻HansBug在一本数学书里面发现了一个神奇的数列,包含N个实数.他想算算这个数列的 ...
- 【洛谷5月月赛】玩游戏(NTT,生成函数)
[洛谷5月月赛]玩游戏(NTT,生成函数) 题面 Luogu 题解 看一下要求的是什么东西 \((a_x+b_y)^i\)的期望.期望显然是所有答案和的平均数. 所以求出所有的答案就在乘一个逆元就好了 ...
- 【洛谷p1031】均分纸牌
[博客园的第一条随笔,值得纪念一下] 均分纸牌[传送门] 洛谷上的算法标签是 这道题是一道贪心题,过了四遍才过(蒟蒻有点废) 第一遍的时候考虑的非常少,只想到了求出平均数→求差值→从左往右加差值: 这 ...
- 【BZOJ2830/洛谷3830】随机树(动态规划)
[BZOJ2830/洛谷3830]随机树(动态规划) 题面 洛谷 题解 先考虑第一问. 第一问的答案显然就是所有情况下所有点的深度的平均数. 考虑新加入的两个点,一定会删去某个叶子,然后新加入两个深度 ...
- 洛谷 P3307: bzoj 3202: [SDOI2013] 项链
题目传送门:洛谷P3307.这题在bzoj上是权限题. 题意简述: 这题分为两个部分: ① 有一些珠子,每个珠子可以看成一个无序三元组.三元组要满足三个数都在$1$到$m$之间,并且三个数互质,两个珠 ...
随机推荐
- 给你的WP应用加上帮助文档
背景 这算是Windows Phone编程回顾续篇, 接着给大家聊WP开发经验. 在开发了数个WP应用并发布后, 陆续收到很多反馈邮件, 其中接近一半的邮件是在问"某某功能有没有?" ...
- my.conf 修改编码
mysql汉字乱码的原因 mysql默认的编码是Latin1是I-8859-1的别名,但Latin1是不支持汉字的,所以要将其改为UTF-8或GBK 1.关闭mysql服务器,这个很重要. 2.通过m ...
- 使用bat执行java项目
前提:java项目要有main方法 类似写法如下: set JAVA_HOME=C:\jdk1.6 set LIB_HOME=. set JAVA_JAR=. set JAVA_JAR=%JAVA_J ...
- BZOJ 1816 扑克牌(二分)
由于答案具有单调性,考虑二分答案并验证. 如果能凑齐x堆,因为每个joke在一个牌堆里最多只能用一次,则至多只能用min(x,m)个joke. 对于每个牌,如果这个牌的总数小于x,用joke补齐剩下的 ...
- 【codevs1282】约瑟夫问题 Treap
题目描述 有编号从1到N的N个小朋友在玩一种出圈的游戏.开始时N个小朋友围成一圈,编号为I+1的小朋友站在编号为I小朋友左边.编号为1的小朋友站在编号为N的小朋友左边.首先编号为1的小朋友开始报数,接 ...
- Go语言【第十三篇】:Go语言递归函数
Go语言递归函数 递归,就是在运行的过程中调用自己,语法格式如下: func recursion() { recursion() /* 函数调用自身 */ } func main() { recurs ...
- BZOJ4299 Codechef FRBSUM(主席树)
感觉非常不可做,于是考虑有什么奇怪的性质. 先考虑怎么求子集和mex.将数从小到大排序,假设已经凑出了0~n的所有数,如果下一个数>n+1显然mex就是n+1了,否则若其为x则可以凑出1~n+x ...
- python 内存分析
1.改源码重新编译打印相关信息 obmalloc.c 文件中打印 maxarenas,值为当前环境分配 arena 个数:分配 arena 时并没有马上分配对应的pools,故对于每一个 arena, ...
- poj 1018 Communication System (枚举)
Communication System Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 22380 Accepted: ...
- 前端开发学习之——使用jquery/javascript判断及改变checkbox选中状态
一.使用jquery判断及改变checkbox选中状态 1.使用JQuery判断一个checkbox 是否为选中: (1).attr('checked) 看JQuery版本1.6+返回:”checke ...