【贪心】【POJ3154】墓地雕塑(Graveyard, NEERC 2006, LA 3708)需要稍稍加工的(先贪心,再确保能这样贪(可行性&&如果可行必定最优&&非证明最优性)的题)(K)
例题4 墓地雕塑(Graveyard, NEERC 2006, LA 3708)
在一个周长为10000的圆上等距分布着n个雕塑。现在又有m个新雕塑加入(位置可以随意放),希望所有n+m个雕塑在圆周上均匀分布。这就需要移动其中一些原有的雕塑。要求n个雕塑移动的总距离尽量小。
【输入格式】
输入包含若干组数据。每组数据仅一行,包含两个整数n和m(2≤n≤1 000,1≤m
≤1 000),即原始的雕塑数量和新加的雕塑数量。输入结束标志为文件结束符(EOF)。
【输出格式】
输入仅一行,为最小总距离,精确到10-4。
【样例输入】
2 1
2 3
3 1
10 10
【样例输出】
1666.6667
1000.0
1666.6667
0.0
这道题 是一边写博客 一边思考的一道题
首先 显然发现 +了雕像后 可以保证一个雕像始终不会动
这是 10个雕像 变为11个雕像的时候 显然发现因为11个雕像的时候间距小于10个雕像的时候
使得在(11)红线 前面的(10)白线 选择移动到前方更近
在(11)红线 后方的(10)白线 选择移动到后方更近
显然
在m=1的情况下 选择附近最近的搬移位置即可 且能保证不会有2个雕像搬到同一位置
考虑m=2 :
10个雕像 变为12个雕像的时候
3个红色的线就是几条类似上面11时候红色的 分界线
我们可以也发现。。 搬移到附近最近位置即可;
。。。但是只能从图片上看出
严格证明想了一段时间还是没有想出来
好吧 似乎通过严格证明再得出 搬到附近最近的位置这个结论估计是不行的。
只能通过 搬到附近最近的位置这个假设 证明出是最优解 并且证明出不会搬移到同一点(书上解法)
书上面有讲解 不过因为是直接看书得出的题解 我还是过两天自己仿书上写一遍题解吧 (今天10-10)
10-12 再次编辑:
step1:
为了使操作简便 假设长度为N+M(后面知道这一步是这道题的精髓)
step2:
原雕塑位置为pos=((N+M)/N )*i (i=0...N-1)
step3:
根据我们上面的图的操作我们知道要找距离最近的点
(若不搬到同一处 显然是最优的,但不知道是否正确)
那么该如何找最近的点呢?
这就体现了step 1的优越性了
floor(pos+0.5) 即可
四舍五入即为一个寻找最近的整数点的方法不是吗?
新雕塑的位置全部为一个整数点;
所以是一个十分赞的方法
程序流程到此结束
证明:
为何这样是正确的?证明可行性
反证法:
假设有两个原雕塑搬到同一点 比如 2
那么 两个雕塑相距最远的可能是什么?
1.49999999999 与 2.49999999999
即使这样两者距离也不过是等于1
显然可知原雕塑距离一定要大于1的
固不可能搬到同一点(这也是当时缩放的一个好处,便于推理)
小贴士:
如果考试的时候无法证明这一点怎么办?
不如从1 for 到 10000 打表证明不存在这种情况
打表程序如下:
AC代码如下:
#include<cstdio>
#include<cmath>
using namespace std;
int main()
{
int n,m;
double pos,ans;
while(scanf("%d%d",&n,&m)!=EOF)
{
ans=0;
for(int i=0;i<n;i++)
{
pos=(double)(n+m)/n*i;
ans=ans+abs(floor(pos+0.5)-pos);
}
printf("%.4lf\n",ans*10000/(double)(n+m));
}
return 0;
}
【贪心】【POJ3154】墓地雕塑(Graveyard, NEERC 2006, LA 3708)需要稍稍加工的(先贪心,再确保能这样贪(可行性&&如果可行必定最优&&非证明最优性)的题)(K)的更多相关文章
- 墓地雕塑-LA3708
https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=20& ...
- UVA LA 7146 2014上海亚洲赛(贪心)
option=com_onlinejudge&Itemid=8&page=show_problem&category=648&problem=5158&mosm ...
- C/C++每日小练(七)——墓地雕塑
墓地雕塑 题目描写叙述: 在一个周长为10000的圆上等距分布着n个雕塑. 如今又有m个新雕塑增加(位置能够任意放).希望全部n+m个雕塑在圆周上均匀分布.这就须要移动当中一些原有的雕塑.要求n个雕塑 ...
- Java实现蓝桥杯墓地雕塑
墓地雕塑 问题描述 在一个周长为10000的圆上等距分布着n个雕塑.现在又有m个新雕塑加入(位置可以随意放), 希望所有n+m个雕塑在圆周上均匀分布.这就需要移动其中一些原有的雕塑.要求n个雕塑移动的 ...
- LA 3708
题意: 在一个周长为10000的圆上等距分布着n 个雕塑,现在又有m 个新雕塑加入(位置可以随意放置), 希望所有(n+m)个雕塑在圆周上均匀分布,这就需要移动其中一些雕塑,要求n个雕塑移 ...
- LA 3708 Graveyard 墓地雕塑 NEERC 2006
在一个周长为 10000 的圆上等距分布着 n 个雕塑.现在又有 m 个新雕塑加入(位置可以随意摆放),希望所有 n + m 个雕塑能在圆周上均匀分布.这就需要移动一些原有的雕塑.要求 n 个雕塑移动 ...
- [ACM_数学] LA 3708 Graveyard [墓地雕塑 圈上新加点 找规律]
Description Programming contests became so popular in the year 2397 that the governor of New Earck ...
- LA 3708 墓地雕塑
题目链接:https://vjudge.net/contest/132704#problem/D 题意:一个长度为10000的园上,均匀分布n个雕塑,现在要加入m个雕塑,这样原先的就可能会移动,求移动 ...
- LA 3708 墓地雕塑(模拟)
题目链接:https://vjudge.net/problem/UVALive-3708 这道题的思路也是比较难想. 首先根据上一题(Uva 11300)可知,要想让移动距离最短,那么至少要使一个雕塑 ...
随机推荐
- asp.net UpdatePanel 不能局部刷新问题汇总
1.web.config 配置问题. 关于web.config的配置方面网上有很多资料参考,按照其方法做即可实现. 2.网站 Framework 版本变化造成不能局部刷新问题 版本更新时,会 ...
- 关闭显卡快捷键 CTRL+ALT+方向键
eclipse中的CTRL+ALT+方向键 会和电脑的快捷键进行冲突,按照以下的方法就可以解决了 打开控制面板,找到“显示”(图中圈划的),点击进入 找到”更改显示器设置“,点击进入 ...
- NSNotification消息
注册消息 [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(方法) name:@"消息名字&q ...
- iOS系统相册的有关操作
iOS中,我们选择相册中的资源和调用摄像头可以使用 :UIImagePickerController类来完成,不使用UI我们可以通过:ALAssetsLibrary类来使用相册资源. 一. ALAss ...
- 拥有iframe页面的子父类窗口调用JS的方法,并且注意的事项
一.前言 我页面用的是EasyUI的弹出窗口里面嵌入一个iframe.第一:父窗口打开子窗口是一个新增用户信息的iframe子页面,点击保存后,子窗口iframe则去调用父窗口的function cl ...
- ARM编译空间属性(转)
原文地址:http://www.cnblogs.com/hongzg1982/articles/2205093.html 1. 程序的空间属性 一般情况下,一个程序本质上都是由 bss段.data段. ...
- Qt Creator下载
Qt官网 http://qt.digia.com qt的历史版本可以到http://download.qt-project.org/archive/qt/下载
- Javascript经典实例 - 正则表达式
1] 正则常用字符 正则表达式常用的特殊字符 字符 匹配 示例 ^ 匹配输入的开始 /^This/匹配 “This is ...” $ 匹配输入的结束 /end$/匹配“This is the end ...
- [C++程序设计]用数组名作函数参数
1. 用数组元素作函数实参 #include <iostream> using namespace std; int max_value(int x, int max) { return ...
- 愉快的开始 - 零基础入门学习Python000
愉快的开始 让编程改变世界 Change the world by program 为什么是Python 既然有各种各样的编程语言可以选择,小甲鱼为什么极力鼓励大家来学习Python呢? 跨平台哦亲 ...