alpq654321 (命题人)
 
基准时间限制:4 秒 空间限制:131072 KB 分值: 80
LYK有一个长度为n的序列a。

他最近在研究平均数。
他甚至想知道所有区间的平均数,但是区间数目实在太多了。
为了方便起见,你只要告诉他所有区间(n*(n+1)/2个区间)中第k大的平均数就行了。
Input
  1. 第一行两个数n,k(1<=n<=100000,1<=k<=n*(n+1)/2)。
  2. 接下来一行n个数表示LYK的区间(1<=ai<=100000)。
Output
  1. 一行表示第k大的平均数,误差不超过1e-4就算正确。
Input示例
  1. 5 3
  2. 1 2 3 4 5
Output示例
  1. 4.000
  1. /*
  2. 51nod 平均数
  3.  
  4. 题目:给你n个数,可以知道总共可以组成 (n+1)*n/2 个区间,那么请问这些区间中第k大的平均值
  5. 最开始是一点思路都没有,后来看到一个有点相似的题目,发现我们可以吧问题转换成 平均值大于
  6. x的区间有多少个
  7.  
  8. 这样就可以通过枚举答案,然后通过判断解决。用f[i]表示前i个数的和,那么:
  9. Ave = (f[r]-f[l])/(r-l) 所以Ave >= x ---> f[r]-rx >= f[l]-lx即前面出现的比当前值小的个数
  10. 但是发现 f[r]-rx 可以达到-10^10,而且是浮点型。于是又纠结了很久,一开始也想到了离散化(但总觉得会超时Orz)
  11. 结果发现的确是自己想太多,利用sort,每次查找当前值是第几个,然后利用树状数组维护即可。
  12.  
  13. hhh 2016/05/28 16:22:06
  14. */
  15. #include <iostream>
  16. #include <vector>
  17. #include <cstring>
  18. #include <string>
  19. #include <cstdio>
  20. #include <queue>
  21. #include <cmath>
  22. #include <algorithm>
  23. #include <functional>
  24. #include <map>
  25. using namespace std;
  26. #define lson (i<<1)
  27. #define rson ((i<<1)|1)
  28. typedef long long ll;
  29. using namespace std;
  30. const int maxn = 101010;
  31. const double PI = 3.1415926;
  32. const double eps = 1e-6;
  33. double a[maxn];
  34. ll s[maxn];
  35. double f[maxn];
  36. double g[maxn];
  37. int n;
  38. ll k;
  39.  
  40. void add(int x,int val)
  41. {
  42. while(x <= 100000)
  43. {
  44. s[x] += val;
  45. x += (x&(-x));
  46. }
  47. }
  48.  
  49. ll sum(int pos)
  50. {
  51. ll ans = 0;
  52. while(pos > 0)
  53. {
  54. ans += s[pos];
  55. pos -= (pos&(-pos));
  56. }
  57. return ans;
  58. }
  59.  
  60. bool cal(double x)
  61. {
  62. memset(s,0,sizeof(s));
  63. f[0] = 0;
  64. for(int i = 1; i <= n; i++)
  65. f[i] = f[i-1] + a[i];
  66. ll num = 0;
  67. for(int i = 1; i <= n; i++)
  68. {
  69. f[i] -= (double)i*x;
  70. g[i] = f[i];
  71. if(f[i] > 0)
  72. num ++;
  73. }
  74. sort(g+1,g+n+1);
  75.  
  76. // for(int i = 1;i <= n;i++)
  77. // cout << g[i] <<" ";
  78. // cout << endl;
  79. for(int i = 1; i <= n; i++)
  80. {
  81. int pla = lower_bound(g+1,g+n+1,f[i])-g;
  82. num += sum(pla);
  83. add(pla,1);
  84. }
  85. if(num >= k)
  86. return true;
  87. else
  88. return false;
  89. }
  90.  
  91. int main()
  92. {
  93. //freopen("in.txt","r",stdin);
  94. scanf("%d",&n);
  95. scanf("%lld",&k);
  96. double Max = 0;
  97. for(int i = 1; i <= n; i++)
  98. {
  99. scanf("%lf",&a[i]);
  100. Max = max(a[i],Max);
  101. }
  102. double l = 0;
  103. double r = Max;
  104. while( r - l > eps)
  105. {
  106. double mid = (l+r)/2;
  107. if(cal(mid))
  108. l = mid;
  109. else
  110. r = mid-eps;
  111. }
  112. printf("%f\n",l);
  113. return 0;
  114. }

  

51nod 平均数(马拉松14)的更多相关文章

  1. 51nod算法马拉松14

    这次太丢人了只搞出来了A到D,那就将就写一写A到D... A 棋盘问题 脑筋急转弯题,不难发现每一次两个人只能染白奇数个格子,所以数数有奇数还是偶数个白格子就行了. #include<cstdi ...

  2. 51NOD 算法马拉松8

    题目戳这里:51NOD算法马拉松8 某天晚上kpm在玩OSU!之余让我看一下B题...然后我就被坑进了51Nod... A.还是01串 水题..怎么乱写应该都可以.记个前缀和然后枚举就行了.时间复杂度 ...

  3. 51nod 算法马拉松 34 Problem D 区间求和2 (FFT加速卷积)

    题目链接  51nod 算法马拉松 34  Problem D 在这个题中$2$这个质数比较特殊,所以我们先特判$2$的情况,然后仅考虑大于等于$3$的奇数即可. 首先考虑任意一个点对$(i, j)$ ...

  4. 51Nod 算法马拉松21(迎新年)

    这次打算法马拉松是在星期五的晚上,发挥还算正常(废话,剩下的题都不会= =). 讲讲比赛经过吧. 8:00准时发题,拿到之后第一时间开始读. A配对,看上去像是二分图最大权匹配,一看范围吓傻了,先跳过 ...

  5. 随便玩玩系列之一:SPOJ-RNG+51nod 算法马拉松17F+51nod 1034 骨牌覆盖v3

    先说说前面的SPOJ-RNG吧,题意就是给n个数,x1,x2,...,xn 每次可以生成[-x1,x1]范围的浮点数,把n次这种操作生成的数之和加起来,为s,求s在[A,B]内的概率 连续形的概率 假 ...

  6. 51Nod 算法马拉松15 记一次悲壮而又开心的骗分比赛

    OwO 故事的起源大概是zcg前天发现51Nod晚上有场马拉松,然后他就很开心的过去打了 神奇的故事就开始了: 晚上的时候我当时貌似正在写线段树?然后看见zcg一脸激动告诉我第一题有九个点直接输出B就 ...

  7. 51Nod 算法马拉松23 开黑记

    惨啊……虽然开了半天黑,但是还是被dalao们踩了…… 第二次开黑,还是被卡在rank20了,我好菜啊……= = 写一写比赛经过吧…… 看到题之后习惯性都打开,A~D看上去似乎并没有什么思路,F应该是 ...

  8. 51Nod 算法马拉松22 开黑记

    这是一场惨烈的开黑大战,始于全机房开黑指望刷进rank前十拿钱的壮志,终于被各路神犇怒踩成rank20,差点200点头盾不保的落魄,想起将近一年前ad和zcg等学长挤进rank10的壮举,不由得唏嘘, ...

  9. 51nod平均数

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

随机推荐

  1. Linux学习--线程概念

    线程 我们知道 ,进程在各自独立的地址空间中运行,进程之间共享数据需要用mmap或者进程间通信机制,本节我们学习如何在一个进程的地址空间中执行多个线程.有些情况需要在一个进程中同时执行多个控制流程,这 ...

  2. SUN平台服务器光纤共享存储互斥失败如何恢复数据?

    服务器数据恢复故障描述: 服务器最初的设计思路为将两台SPARC SOLARIS系统通过光纤交换机共享同一存储作为CLUSTER使用,正常情况下A服务器工作,当A服务器发生故障宕机后即可将其关机然后开 ...

  3. SQL语句取多列的最小值(排除0)

    经常遇到获取数据表中多个列的最小值和最大值,例如: 获取这 4个价格的最小值和最大值: SELECT( SELECT min(minPrice) FROM ( VALUES (IIF(MarketSi ...

  4. 易错点---所有的字符都自带bool值

    所有的字符都自带布尔值,只有0,None,空为False,其他全部为真!!!!!!!!!!! count = 0 while count < 3 : inp_age =input('Enter ...

  5. sql2008r2,以前好好可以用的,但装了vs2017后,连接不上了,服务也停了,结果手动也 启动不了, 无法加载或初始化请求的服务提供程

    日志: 2017-12-14 12:33:17.53 服务器 A self-generated certificate was successfully loaded for encryption.2 ...

  6. Linux的打印rpm包的详细信息的shell脚本

    #!/bin/bash # list a content summary of a number of RPM packages # USAGE: showrpm rpmfile1 rpmfile2 ...

  7. nodejs 使用CAS 实现 单点登录(SSO) 【开源库实现,简单】

    大部分企业使用 java 开发业务系统, 针对java cas的认证 demo 比较多 ,还有PHPCAS ,标准的参考这里: phpCAS 的使用 整理登录流程如下图,图片来自网络 找了不少资料,n ...

  8. maven 每次update后影响接口实现类的问题

    遇到maven每次update后,就会更改eclipse中java Compiler中的jdk compliance版本 <plugin> <groupId>org.apach ...

  9. 什么是MQTT协议?

    MQTT协议介绍 MQTT协议是什么? MQTT(Message Queuing Telemetry Transport Protocol)的全称是消息队列遥感传输协议的缩写,是一种基于轻量级代理的发 ...

  10. xftp上传文件失败,执行程序发现磁盘满了:No space left on device

    参考链接 No space left on device 解决Linux系统磁盘空间满的办法http://www.cnblogs.com/aspirant/p/3604801.html如何解决linu ...