题目

描述

题目大意

有一堆长为222的矩形,最下面的右端点横坐标为000。

每个矩形都有其固定的质量。

将这些矩形堆在一起,使得最右边的横坐标最大,并且满足它不会塌掉(满足物理学)。


思考历程

首先就觉得这是一道结论题。

这个东西看起来不可以DP做,所以就往贪心的方面想。

我想从上往下推过来,计算出可能的最左和最右的重心的位置。

在计算的时候记录一下最右边的点。

实际上我的这个想法存在着太多的漏洞,以至于我连样例也没有过。


正解

首先,最优的方案一定是长成“>>>”形状的。

接下来我们枚举这个凸出来的矩形,设其为xxx。

在xxx下面的尽量往右伸,在xxx上面的往左伸。右伸是为了使得答案尽量大,左伸是为了让答案尽量大的时候可以保持平衡。

现在我们需要让xxx以及它上面的矩形可以立足于x−1x-1x−1的矩形上。

由于xxx要尽量往右,那我们就钦定这一大块的重心在rx−1r_{x-1}rx−1​处(rir_iri​表示iii矩形的右边横坐标)

又由于xxx上面的矩形要往左,所以我们就钦定它们的重心在rx−2r_x-2rx​−2上(一定有满足这种条件的方案)。

设MMM为xxx上面的矩形的质量和,mxm_xmx​为xxx的质量,依照公式:

rx−1=M(rx−2)+mx(rx−1)M+mxr_{x-1}=\frac{M(r_x-2)+m_x(r_x-1)}{M+m_x}rx−1​=M+mx​M(rx​−2)+mx​(rx​−1)​

如果我们知道rx−1r_{x-1}rx−1​,就可以解出rxr_xrx​,然后统计入答案。

那这个rx−1r_{x-1}rx−1​是怎么来的呢?

显然不可以有上一次i=x−1i=x-1i=x−1时解出来的结果,具体原因不在赘述。

转化成另一个问题,现在xxx不是最右边的矩形,最右边的矩形会出现在它的上方。

所以xxx上面的矩形要尽量往右伸,我们可以将它们的重心钦定为rxr_xrx​,然后方程就出来了。

rx−1=Mrx+m(rx−1)M+mzr_{x-1}=\frac{Mr_x+m(r_x-1)}{M+m_z}rx−1​=M+mz​Mrx​+m(rx​−1)​

同样可以通过rx−1r_{x-1}rx−1​解出rxr_xrx​,解出之后用来更新现在的rx−1r_{x-1}rx−1​,计算下一个答案。

时间显然是线性的。


代码

using namespace std;
#include <cstdio>
#include <cstring>
#include <algorithm>
#define N 300010
int n;
int w[N];
int main(){
scanf("%d",&n);
double sum=0;
for (int i=1;i<=n;++i)
scanf("%d",&w[i]),sum+=w[i];
sum-=w[1];
double r=0,ans=0;
for (int i=2;i<=n;++i){
sum-=w[i];
ans=max(r+1+sum/(sum+w[i]),ans);
r=r+w[i]/(sum+w[i]);
}
printf("%.8lf\n",ans);
return 0;
}

总结

在贪心的时候,有时可以“钦定”一下,假设除最好的情况来计算。

[JZOJ3171] 【GDOI2013模拟4】重心的更多相关文章

  1. jzoj3156. 【GDOI2013模拟1】病毒传播

    题意: 村庄里有m个人,初始有一些人感染了病毒.如果第i个人的编号i满足,有一对(a,b)(a是初始病毒感染者编号,b为前一天的感染者编号)使\(a*b mod m =i\),则第i个人会感染病毒.每 ...

  2. 【GDOI2013模拟4】贴瓷砖

    题目 A镇的主街是由N个小写字母构成,镇长准备在上面贴瓷砖,瓷砖一共有M种,第i种上面有Li个小写字母,瓷砖不能旋转也不能被分割开来,瓷砖只能贴在跟它身上的字母完全一样的地方,允许瓷砖重叠,并且同一种 ...

  3. [JZOJ3168] 【GDOI2013模拟3】踢足球

    题目 描述 题目大意 有两个队伍,每个队伍各nnn人. 接到球的某个人会再下一刻随机地传给自己人.敌人和射门,射门有概率会中. 每次射门之后球权在对方111号选手. 某个队伍到了RRR分,或者总时间到 ...

  4. [JZOJ3167] 【GDOI2013模拟3】查税

    题目 描述 题目大意 维护一个有一次函数组成的序列 具体来说,对于位置xxx,现在的值为sx+zx∗(T−tx)s_x+z_x*(T-t_x)sx​+zx​∗(T−tx​) 有两个操作,修改某个位置上 ...

  5. [JZOJ3177] 【GDOI2013模拟5】安全监控

    题目 描述 (样例都懒得发出来了) 题目大意 给你一个有向图,从111号点出发,绕一圈回来.这一圈中必须经过222号点. 问经过的最少的点数(不重复). 思考历程 一看就觉得是一道神题. 然后仔细观察 ...

  6. [JZOJ3187]【GDOI2013模拟8】的士

    题目 描述 题目大意 在一个数轴上,有些人要从某个点到达另一个点. 出租车从最左端出发,将所有人送到它们的目的地,最终到达最右边的点. 出租车只能做一个乘客,并且可以在图中将乘客丢下. 问最短时间. ...

  7. 不熟,不会,未a的题列表

    不熟: jzoj5968. 电竞选手(不知道公式如何得来) jzoj4877. [NOIP2016提高A组集训第10场11.8]力场护盾 (对向量不熟悉,不知道为什么结果要取反) jzoj4867. ...

  8. 【CSP模拟赛】仔细的检查(树的重心&树hash)

    题目描述 nodgd家里种了一棵树,有一天nodgd比较无聊,就把这棵树画在了一张纸上.另一天nodgd更无聊,就又画了一张.  这时nodgd发现,两次画的顺序是不一样的,这就导致了原本的某一个节点 ...

  9. hdu-1115 计算几何 求重心 凸多边形 面积

    思想是分割成三角形,然后求三角形的重心.那么多边形重心就是若干个三角形的重心带权求中心,可以用质点质心公式. #include <cstdio> #include <iostream ...

随机推荐

  1. ionic-CSS:ionic icon(图标)

    ylbtech-ionic-CSS:ionic icon(图标) 1.返回顶部 1. ionic icon(图标) ionic 也默认提供了许多的图标,大概有 700 多个,针对 Android 和 ...

  2. CodeForces 1152F2 Neko Rules the Catniverse (Large Version)

    题目链接:http://codeforces.com/problemset/problem/1152/F2 题目大意 见http://codeforces.com/problemset/problem ...

  3. Eclipse+Maven创建webapp项目 及部署在tomcat上

    1.开启eclipse,右键new——>other,如下图找到maven project 2.选择maven project,显示创建maven项目的窗口,勾选如图所示,Create a sim ...

  4. ps-通道错位制作奇幻海报

    效果图 素材 1.载入素材 点击通道 点击下面的蓝色通道,全选-复制 点击绿色通道,全选-黏贴 编辑-变化-水平翻转 点击RGB即可.

  5. 【POJ】2236 Wireless Network

    题目链接:http://poj.org/problem?id=2236 题意:给你n台计算机的坐标.d是可通信的最大距离.有两个操作. 1.O p 表示修复计算机p. 2.S p q表示询问pq是否能 ...

  6. 无LoadLibrary获取指定模块基址

    实际上,这块可以写成汇编,然后做远程注入用 方法 1.通过fs:[30h]获取当前进程的_PEB结构 2.通过_PEB的Ldr成员获取_PEB_LDR_DATA结构 3.通过_PEB_LDR_DATA ...

  7. Activiti学习笔记8 — UserTask私有任务的使用

    每一个UserTask都会在Execution表和Task表中各产生一条记录 一.创建流程引擎对象 /** * 1.创建流程引擎对象 */ private ProcessEngine processE ...

  8. JS对象 提取指定数目的字符substr() substr() 方法从字符串中提取从 startPos位置开始的指定数目的字符串。

    提取指定数目的字符substr() substr() 方法从字符串中提取从 startPos位置开始的指定数目的字符串. 语法: stringObject.substr(startPos,length ...

  9. linux上给其他在线用户发送信息(wall, write, talk, mesg)

        linux上给其他在线用户发送信息(wall, write, talk, mesg)   2018-01-05 lonskyMR 转自 恶之一眉 修改 微信分享: 设置登录提示     /et ...

  10. Excel宏开发之合并单元格

    合并单元格 Sub 宏1() ' ' 宏1 宏 ' ' 快捷键: Ctrl+q ' Application.Goto Reference:="宏1" Application.VBE ...