洛谷 P2797 Facer的魔法 解题报告
P2797 Facer的魔法
题意:给你n个数,你可以选若干个数,使得平均数减中位数最大
数据范围:\(n \le 10^5\)
原题CF626E
很容易想到枚举一个中位数,但是如果选取的数字的个数是偶数个该怎么办呢?
下面证明选取奇数个时一定可以作为答案
当选取一个数字时,答案为0,所以最优答案不可能小于0,这点很重要
现在,我们假设选取了\(2k\)个有序的数成为了答案
设中位数为\(M_0=\frac{a_k+a_{k+1}}{2}\),平均数为\(A_0=\frac{\sum a}{2k}\)
拿掉一个\(a_{k+1}\)后答案会变差吗
设拿掉一个\(a_{k+1}\)后
\(M_1=a_k,A_1=\frac{\sum a-a_{k+1}}{2k-1}\)
\(\Delta M=M_1-M_0=\frac{a_k-a_{k+1}}{2}\)
\(\Delta A=\frac{A_0-a_{k+1}}{2k-1}\)
现在要证\(\Delta A \ge \Delta M\)
因为最优答案大于0,所以有
\(2 \times A_0 \ge a_k+a_{k+1}\)
继续证明
$\Delta A \ge \Delta M $
\(\Rightarrow \frac{A_0-a_{k+1}}{2k-1}+\frac{a_{k+1}-a_k}{2} \ge 0\)
\(\Rightarrow \frac{2A_0-2a_{k+1}+(2k-1)(a_{k+1}-a_k)}{(2k-1) \times 2} \ge 0\)
\(\Rightarrow a_k-a_{k+1} +(2k-1)(a_{k+1}-a_k) \ge 0\)
这一步用了上面的东西,并把正的分母去掉了
\(\Rightarrow 2 \times (k-1)(a_{k+1}-a_k) \ge 0\)
然而仅仅枚举中位数,就算我们贪心每次选大的数也需要\(O(n^2)\)的时间啊
我们从枚举的中位数的左边第一位和右边最后一位 一位一位的向左多选
因为选取的数字越来越小,所以平均数的增量肯定越来越小,其实这个不那么显然,但是证起来比较麻烦
而大家基本上可以理解理解啦
增量减少,值一定有一个峰顶,这是一个单峰函数,我们可以通过三分法找到这个峰顶
注意在整数域上三分要注意边界问题
我们可以这么写
\(lmid=(l*2+r)/3,rmid=(l+r*2+2)/3\)
Code:
#include <cstdio>
#include <algorithm>
const int N=1e5+10;
double ans=0;int a[N],f[N],n;
double max(double x,double y){return x>y?x:y;}
int min(int x,int y){return x<y?x:y;}
int F(int pos,int len)
{
return f[pos]-f[pos-len-1]+f[n]-f[n-len];
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%d",a+i);
std::sort(a+1,a+1+n);
for(int i=1;i<=n;i++) f[i]=f[i-1]+a[i];
for(int i=2;i<n;i++)
{
int l=1,r=min(i-1,n-i);
while(l<r)
{
int ll=(l*2+r)/3,rr=(l+r*2+2)/3;
if(F(i,ll)*(rr*2+1)<F(i,rr)*(ll*2+1))
l=ll+1;
else
r=rr-1;
}
ans=max(ans,1.0*F(i,l)/(l*2+1)-1.0*a[i]);
}
printf("%.2lf\n",ans);
return 0;
}
2018.9.6
洛谷 P2797 Facer的魔法 解题报告的更多相关文章
- 洛谷 P2801 教主的魔法 解题报告
P2801 教主的魔法 题目描述 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.--.N. ...
- 洛谷_Cx的故事_解题报告_第四题70
1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h> struct node { long x,y,c; ...
- 洛谷 P3802 小魔女帕琪 解题报告
P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...
- 洛谷 P2317 [HNOI2005]星际贸易 解题报告
P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...
- 洛谷 P2606 [ZJOI2010]排列计数 解题报告
P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...
- 洛谷1303 A*B Problem 解题报告
洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...
- 洛谷 P2195 HXY造公园 解题报告
P2195 HXY造公园 题目描述 现在有一个现成的公园,有\(n\)个休息点和\(m\)条双向边连接两个休息点.众所周知,\(HXY\)是一个\(SXBK\)的强迫症患者,所以她打算施展魔法来改造公 ...
- 洛谷 P3084 [USACO13OPEN]照片Photo 解题报告
[USACO13OPEN]照片Photo 题目描述 农夫约翰决定给站在一条线上的\(N(1 \le N \le 200,000)\)头奶牛制作一张全家福照片,\(N\)头奶牛编号\(1\)到\(N\) ...
- 洛谷 P1379 八数码难题 解题报告
P1379 八数码难题 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初 ...
随机推荐
- Java分享笔记:泛型机制的程序演示
package packA; import java.util.*; public class GenericDemo { public static void main(String[] args) ...
- xml的应用与dtd约束
1.xml的应用 *不同的系统之间的传输数据(qq消息传输) *用来表示生活中有关系的数据(省市区的包含关系) *经常用在文件配置 **比如现在连接数据库,肯定知道数据库的名称和密码及用户名. ...
- php 图片操作类,支持生成缩略图,添加水印,上传缩略图
<?php class Image { //类开始 public $originimage = ""; //源图片文件地址 public $image ...
- html5的canvas绘制线条,moveTo和lineTo详解
今天在看html5,里面新增的属性有一个canvas,它相当于一个画布你可以用js在里面画你想要的效果!我在w3c的手册里面看到用moveTo和lineTo绘制线条讲的不是很清楚,尤其是moveTo和 ...
- 2、spring boot 配置文件
配置文件 SpringBoot使用一个全局的配置文件,配置文件名是固定的: •application.properties •application.yml 配置文件的作用:修改SpringBoot自 ...
- debug注意事项
1 先看关键代码是否正确,然后查一遍是否有变量名打错. 2 再看初始化有没有问题 3 再把范围开大和开int64(这应该刚开始看题就要注意,在不爆内存的情况下开int64) 4 静态调试,输出中间值. ...
- PHP.31-TP框架商城应用实例-后台7-商品会员修改-页面优化,多表数据更新
商品表修改功能 1.页面优化,类似添加页面 <layout name="layout" /> <div class="tab-div"> ...
- 8 Django 模型层(1)--orm简介
ORM简介 MVC或者MVC框架中包括一个重要的部分,就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖于特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的 ...
- MyBatis---简单增删改查的带事物的例子
本例子包含了对数据库表简单的增删改查的操作,并且包含事物.该例子只适用于MySQL数据库.该例子需要手动创建数据库以及数据库表 例子中所需要的jar包,详查MyBatis---简介 一个entity类 ...
- 13 KNN背景分割器
传统的前景背景分割方法有GrabCut,分水岭算法,当然也包括一些阈值分割的算法.但是这些算法在应用中往往显得鲁棒性较弱,达不到一个好的分割效果. 现代的背景分割算法融入了机器学习的一些方法来提高分类 ...