【洛谷】P4594 [COCI2011-2012#5] BLOKOVI
本来已经有一个专门记录洛谷题目的博客了,但这个题之毒瘤。。。。。。
为你专门写一篇总行了吧。。。。。。
先说一句,这个题每次摆放都靠到最右边不一定是最优的
因为它可以这个亚子
就是说上面那个块太重了,可以把下面向右伸的块压住(这不就是样例吗嘚瑟个啥
接下来说一说正解的思路
从下往上放的时候,每一次加入都要考虑每一层重心的变化,很麻烦,所以还是从上往下放(相当于插入
然后发现插入最底下那一层的矩形时,因为这个矩形不能变,所以上方的n-1个矩形肯定是越靠右越优
最右的时候就是当上方的n-1矩形的重心恰好在它的右端点。
此时答案就相当于最右端点到重心的距离
所以我们可以去求最右端点到当前重心距离的最值
设$dp[i]$表示前$i$个矩形摆放好后最右端点到它们的重心距离的最大值
接下来可以来试着从$dp[i-1]$递推到$dp[i]$
先从理论计算的角度来看,接下来的转移方法来自别人的博客,思路是枚举前$i-1$个矩形的重心在第$i$个矩形的位置然后找到最值。
我们假设已知当前积木$i$质量$mass$,之前所有积木质量$M$,
以积木$i$的左端点为原点,设$i−1$块积木构成的整体的重心在$X$轴的坐标为$x,x∈[0,2]$
新的重心横坐标
$$NewCentre=\frac {M \times x+1 \times mass} {M+mass} =\frac {M \times x+mass}{M+mass}$$
新的最右端可能有两个,一个是之前的那个最右端,另一个是当前木块的右端,取$max$得到坐标就好了
$$Right=Max(2,x+dp[i−1])$$
所以
$$dp[i]=Max(2,x+dp[i−1])− \frac {M \times x+mass}{M+mass}$$
$$=\frac {Max(2 \times M+2 \times mass,x \times (M+mass)+dp[i−1] \times(M+mass))−M \times x−mass}{M+mass}$$
$$=\frac {Max((2−x) \times M+mass,(x−1) \times mass+dp[i−1] \times (M+mass))}{M+mass}$$
可以发现,$Max()$中的两个式子,一个是随着$x$上升单调递增,一个是随着$x$上升单调递减的,均满足单调性,因此直接考虑x=0,2完全是可以的,换句话说,即一个是重心在左端点,一个是重心在右端点.所以答案是在这两个地方产生的。
所以转移的时候直接枚举前$i-1$个矩形的重心是放在左端点还是右端点就行了。
也可以画图理解
红线代表前i-1个矩形的重心所在的垂直于地面的直线,深蓝色是最右端的位置,绿色就是$dp[i-1]$,橙色是第$i$个矩形的重心
先明确目标,我们要找到新重心到原来的右端点距离,即新重心到蓝色直线的距离的最值,
还有新重心到当前矩形的右端点的距离的最值
先求最右端点到新重心距离的最值,我们把新的重心所在直线画出来
就是这条浅紫色的线
根据物理的杠杆原理(雾,其实是感性理解)
新重心所在直线到前i-1个矩形重心所在直线的距离 与 新重心所在直线到第i个矩形重心所在直线的距离 的比例为它们重量的反比
即黄色线段与粉色线段长度的比例为重量的反比。
这个比例我们不用知道具体是多少,只需要知道这个比例只跟重量有关,而前i-1个矩形的重量与第i个矩形的重量是固定的
所以黄色线段与粉色线段的比例是固定的
又发现黄色线段加上粉色线段就是橙色点到红色线段的距离,即原来的两个重心所在直线的距离
所以,原来的两个重心所在直线的距离越长,黄色线段越长。
而新重心到原来右端点的距离就是黄色线段加上绿色线段,且绿色线段的长度是固定的
所以,原来的两个重心所在直线的距离越长,新重心到以前右端点的距离越长。
当然,这只限于红线在右边的情况,还有红线在左边的情况
总之最后可以得出结论,红线越往右,新重心到以前右端点的距离越长,最右的时候就是红线恰好在矩形的右端点处。
接下来看新重心到矩形右端点的最值
就是浅紫色直线到矩形右端点的最值
显然,前i-1的矩形的重心越靠左,新的重心越靠左
即红色直线越靠左,浅色直线越靠左,距离矩形右端点的距离就越远
红色直线最左在矩形左端点,此时新重心到矩形右端点的距离取到最值
所以
新重心到矩形右端点的最值是当红色直线在矩形左端点取得
新重心到以前右端点的最值是当红色直线在矩形右端点取得
所以只需要考虑原来重心在左端点和原来重心在右端点的情况
最终思路就是把矩形从上往下放,记录重心道最右端点的距离,
每次转移只考虑之前重心在左端点和之前重心在右端点的情况
Code
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=;
int n,a[maxn];double sum,ans;
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
for(int i=n;i>;i--)
{
sum+=a[i];
double del=double(a[i])/sum;
ans=max(ans,max(ans+del,-del));
}
printf("%.8lf",ans);
}
【洛谷】P4594 [COCI2011-2012#5] BLOKOVI的更多相关文章
- 洛谷 3833 SHOI 2012 魔法树
[题解] 树链剖分模板题.. #include<cstdio> #include<algorithm> #include<queue> #define N 5000 ...
- 洛谷 P1083 [ NOIP 2012 ] 借教室 —— 线段树 / 二分差分数组
题目:https://www.luogu.org/problemnew/show/P1083 当初不会线段树的时候做这道题...对差分什么不太熟练,一直没A,放在那儿不管... 现在去看,线段树就直接 ...
- [洛谷OJ] P1114 “非常男女”计划
洛谷1114 “非常男女”计划 本题地址:http://www.luogu.org/problem/show?pid=1114 题目描述 近来,初一年的XXX小朋友致力于研究班上同学的配对问题(别想太 ...
- 洛谷P1078 文化之旅
P1078 文化之旅 1.1K通过 3.6K提交 题目提供者洛谷OnlineJudge 标签NOIp普及组2012 难度普及+/提高 时空限制1s / 128MB 提交 讨论 题解 最新讨论更多讨 ...
- 【流水调度问题】【邻项交换对比】【Johnson法则】洛谷P1080国王游戏/P1248加工生产调度/P2123皇后游戏/P1541爬山
前提说明,因为我比较菜,关于理论性的证明大部分是搬来其他大佬的,相应地方有注明. 我自己写的部分换颜色来便于区分. 邻项交换对比是求一定条件下的最优排序的思想(个人理解).这部分最近做了一些题,就一起 ...
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
- 洛谷P1108 低价购买[DP | LIS方案数]
题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...
- 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP
题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...
随机推荐
- 一个简单的 WPF 程序,用于显示实时时间
直接贴代码了: TimeShowerWindow.xaml <Window x:Class="HelloWorld.TimeShowerWindow" xmlns=" ...
- 解锁云原生 AI 技能 - 开发你的机器学习工作流
按照上篇文章<解锁云原生 AI 技能 | 在 Kubernetes 上构建机器学习系统>搭建了一套 Kubeflow Pipelines 之后,我们一起小试牛刀,用一个真实的案例,学习如何 ...
- Pandas 学习 第9篇:DataFrame - 数据的输入输出
常用的数据存储介质是数据库和csv文件,pandas模块包含了相应的API对数据进行输入和输出: 对于格式化的平面文件:read_table() 对于csv文件:read_csv().to_csv() ...
- .NET Core on K8S快速入门课程--学习笔记
课程链接:http://video.jessetalk.cn/course/explore 良心课程,大家一起来学习哈! 目录 01-介绍K8s是什么 02-为什么要学习k8s 03-如何学习k8s ...
- Asp.net HttpContext 简介
1. Context 名词解析 Context 直接翻译就是上下文."上下文" 这个名词还是挺让人费解的,是一个非常泛化的概念.刚看到有点让人摸不着头脑,一个高端 ...
- mask-rcnn代码解读(四):rpn_feature_maps数据的处理
此处模拟 rpn_feature_maps数据的处理,最终得到rpn_class_logits, rpn_class, rpn_bbox. 代码如下: import numpy as np'''层与层 ...
- Java获取客户端真实IP地址
Java代码 import javax.servlet.http.HttpServletRequest; /** * 获取对象的IP地址等信息 */ public class IPUtil { /** ...
- Vue笔记--同局域网下访问本地项目
正常开发中有时间提测比较麻烦.通常让测试小姐姐连接开发本地开启的服务器访问本地项目(在同一局域网下). 其实一般项目IDE已经实现这些功能例如webstorm和vscode,有时候需要单独配置下. 但 ...
- Windows+Qt+MinGW使用gRPC
本文参考博客文章Qt gRPC 简单应用进行了亲自尝试,特此记录以下过程,为后人提供经验.我的环境:Windows10 x64需要依赖MSYS2环境(一个类Unix环境,包管理器)MSYS2 gith ...
- Jetty启动报Error scanning entry META-INF/versions/9/org/apache/logging/log4j/util/ProcessIdUtil.class
近日在项目中集成Elasticsearch后,Jetty启动报错. 错误日志如下: Suppressed: |java.lang.RuntimeException: Error scanning en ...