51nod 平均数(马拉松14)
- 第一行两个数n,k(1<=n<=100000,1<=k<=n*(n+1)/2)。
- 接下来一行n个数表示LYK的区间(1<=ai<=100000)。
- 一行表示第k大的平均数,误差不超过1e-4就算正确。
- 5 3
- 1 2 3 4 5
- 4.000
- /*
- 51nod 平均数
- 题目:给你n个数,可以知道总共可以组成 (n+1)*n/2 个区间,那么请问这些区间中第k大的平均值
- 最开始是一点思路都没有,后来看到一个有点相似的题目,发现我们可以吧问题转换成 平均值大于
- x的区间有多少个
- 这样就可以通过枚举答案,然后通过判断解决。用f[i]表示前i个数的和,那么:
- Ave = (f[r]-f[l])/(r-l) 所以Ave >= x ---> f[r]-rx >= f[l]-lx即前面出现的比当前值小的个数
- 但是发现 f[r]-rx 可以达到-10^10,而且是浮点型。于是又纠结了很久,一开始也想到了离散化(但总觉得会超时Orz)
- 结果发现的确是自己想太多,利用sort,每次查找当前值是第几个,然后利用树状数组维护即可。
- hhh 2016/05/28 16:22:06
- */
- #include <iostream>
- #include <vector>
- #include <cstring>
- #include <string>
- #include <cstdio>
- #include <queue>
- #include <cmath>
- #include <algorithm>
- #include <functional>
- #include <map>
- using namespace std;
- #define lson (i<<1)
- #define rson ((i<<1)|1)
- typedef long long ll;
- using namespace std;
- const int maxn = 101010;
- const double PI = 3.1415926;
- const double eps = 1e-6;
- double a[maxn];
- ll s[maxn];
- double f[maxn];
- double g[maxn];
- int n;
- ll k;
- void add(int x,int val)
- {
- while(x <= 100000)
- {
- s[x] += val;
- x += (x&(-x));
- }
- }
- ll sum(int pos)
- {
- ll ans = 0;
- while(pos > 0)
- {
- ans += s[pos];
- pos -= (pos&(-pos));
- }
- return ans;
- }
- bool cal(double x)
- {
- memset(s,0,sizeof(s));
- f[0] = 0;
- for(int i = 1; i <= n; i++)
- f[i] = f[i-1] + a[i];
- ll num = 0;
- for(int i = 1; i <= n; i++)
- {
- f[i] -= (double)i*x;
- g[i] = f[i];
- if(f[i] > 0)
- num ++;
- }
- sort(g+1,g+n+1);
- // for(int i = 1;i <= n;i++)
- // cout << g[i] <<" ";
- // cout << endl;
- for(int i = 1; i <= n; i++)
- {
- int pla = lower_bound(g+1,g+n+1,f[i])-g;
- num += sum(pla);
- add(pla,1);
- }
- if(num >= k)
- return true;
- else
- return false;
- }
- int main()
- {
- //freopen("in.txt","r",stdin);
- scanf("%d",&n);
- scanf("%lld",&k);
- double Max = 0;
- for(int i = 1; i <= n; i++)
- {
- scanf("%lf",&a[i]);
- Max = max(a[i],Max);
- }
- double l = 0;
- double r = Max;
- while( r - l > eps)
- {
- double mid = (l+r)/2;
- if(cal(mid))
- l = mid;
- else
- r = mid-eps;
- }
- printf("%f\n",l);
- return 0;
- }
51nod 平均数(马拉松14)的更多相关文章
- 51nod算法马拉松14
这次太丢人了只搞出来了A到D,那就将就写一写A到D... A 棋盘问题 脑筋急转弯题,不难发现每一次两个人只能染白奇数个格子,所以数数有奇数还是偶数个白格子就行了. #include<cstdi ...
- 51NOD 算法马拉松8
题目戳这里:51NOD算法马拉松8 某天晚上kpm在玩OSU!之余让我看一下B题...然后我就被坑进了51Nod... A.还是01串 水题..怎么乱写应该都可以.记个前缀和然后枚举就行了.时间复杂度 ...
- 51nod 算法马拉松 34 Problem D 区间求和2 (FFT加速卷积)
题目链接 51nod 算法马拉松 34 Problem D 在这个题中$2$这个质数比较特殊,所以我们先特判$2$的情况,然后仅考虑大于等于$3$的奇数即可. 首先考虑任意一个点对$(i, j)$ ...
- 51Nod 算法马拉松21(迎新年)
这次打算法马拉松是在星期五的晚上,发挥还算正常(废话,剩下的题都不会= =). 讲讲比赛经过吧. 8:00准时发题,拿到之后第一时间开始读. A配对,看上去像是二分图最大权匹配,一看范围吓傻了,先跳过 ...
- 随便玩玩系列之一:SPOJ-RNG+51nod 算法马拉松17F+51nod 1034 骨牌覆盖v3
先说说前面的SPOJ-RNG吧,题意就是给n个数,x1,x2,...,xn 每次可以生成[-x1,x1]范围的浮点数,把n次这种操作生成的数之和加起来,为s,求s在[A,B]内的概率 连续形的概率 假 ...
- 51Nod 算法马拉松15 记一次悲壮而又开心的骗分比赛
OwO 故事的起源大概是zcg前天发现51Nod晚上有场马拉松,然后他就很开心的过去打了 神奇的故事就开始了: 晚上的时候我当时貌似正在写线段树?然后看见zcg一脸激动告诉我第一题有九个点直接输出B就 ...
- 51Nod 算法马拉松23 开黑记
惨啊……虽然开了半天黑,但是还是被dalao们踩了…… 第二次开黑,还是被卡在rank20了,我好菜啊……= = 写一写比赛经过吧…… 看到题之后习惯性都打开,A~D看上去似乎并没有什么思路,F应该是 ...
- 51Nod 算法马拉松22 开黑记
这是一场惨烈的开黑大战,始于全机房开黑指望刷进rank前十拿钱的壮志,终于被各路神犇怒踩成rank20,差点200点头盾不保的落魄,想起将近一年前ad和zcg等学长挤进rank10的壮举,不由得唏嘘, ...
- 51nod平均数
#include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...
随机推荐
- Linux学习--线程概念
线程 我们知道 ,进程在各自独立的地址空间中运行,进程之间共享数据需要用mmap或者进程间通信机制,本节我们学习如何在一个进程的地址空间中执行多个线程.有些情况需要在一个进程中同时执行多个控制流程,这 ...
- SUN平台服务器光纤共享存储互斥失败如何恢复数据?
服务器数据恢复故障描述: 服务器最初的设计思路为将两台SPARC SOLARIS系统通过光纤交换机共享同一存储作为CLUSTER使用,正常情况下A服务器工作,当A服务器发生故障宕机后即可将其关机然后开 ...
- SQL语句取多列的最小值(排除0)
经常遇到获取数据表中多个列的最小值和最大值,例如: 获取这 4个价格的最小值和最大值: SELECT( SELECT min(minPrice) FROM ( VALUES (IIF(MarketSi ...
- 易错点---所有的字符都自带bool值
所有的字符都自带布尔值,只有0,None,空为False,其他全部为真!!!!!!!!!!! count = 0 while count < 3 : inp_age =input('Enter ...
- sql2008r2,以前好好可以用的,但装了vs2017后,连接不上了,服务也停了,结果手动也 启动不了, 无法加载或初始化请求的服务提供程
日志: 2017-12-14 12:33:17.53 服务器 A self-generated certificate was successfully loaded for encryption.2 ...
- Linux的打印rpm包的详细信息的shell脚本
#!/bin/bash # list a content summary of a number of RPM packages # USAGE: showrpm rpmfile1 rpmfile2 ...
- nodejs 使用CAS 实现 单点登录(SSO) 【开源库实现,简单】
大部分企业使用 java 开发业务系统, 针对java cas的认证 demo 比较多 ,还有PHPCAS ,标准的参考这里: phpCAS 的使用 整理登录流程如下图,图片来自网络 找了不少资料,n ...
- maven 每次update后影响接口实现类的问题
遇到maven每次update后,就会更改eclipse中java Compiler中的jdk compliance版本 <plugin> <groupId>org.apach ...
- 什么是MQTT协议?
MQTT协议介绍 MQTT协议是什么? MQTT(Message Queuing Telemetry Transport Protocol)的全称是消息队列遥感传输协议的缩写,是一种基于轻量级代理的发 ...
- xftp上传文件失败,执行程序发现磁盘满了:No space left on device
参考链接 No space left on device 解决Linux系统磁盘空间满的办法http://www.cnblogs.com/aspirant/p/3604801.html如何解决linu ...