【bzoj1038】瞭望塔
【bzoj1038】瞭望塔
题意
致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安。我们将H村抽象为一维的轮廓。如下图所示 我们可以用一条山的上方轮廓折线(x1, y1), (x2, y2), …. (xn, yn)来描述H村的形状,这里x1 < x2 < …< xn。瞭望塔可以建造在[x1, xn]间的任意位置, 但必须满足从瞭望塔的顶端可以看到H村的任意位置。可见在不同的位置建造瞭望塔,所需要建造的高度是不同的。为了节省开支,dadzhi村长希望建造的塔高度尽可能小。请你写一个程序,帮助dadzhi村长计算塔的最小高度。
分析
分析1:模拟退火+二分
调不出来。
调得出来的时候估计阳寿已尽。
有生之年内应该不会调得出来吧。
就放一个半成品代码吧。
#include <cstdio>
#include <cctype>
#include <cmath>
#include <ctime>
#include <algorithm>
using namespace std;
#define rep(i,a,b) for (int i=(a);i<=(b);i++)
const int N=512;
const double MAX=1e11;
const double EPS=1e-6;
const int T=1;
const double SPEED=0.99;
const double END=0.00001;
int rd(void);
int n;
struct point {
double x,y;
point(double _x=0,double _y=0) {
x=_x,y=_y;
}
friend point operator - (point a,point b) {
return point(a.x-b.x,a.y-b.y);
}
}p[N];
double det(point a,point b) {
return a.x*b.y-a.y*b.x;
}
double now; double nd;
double ans;
int rd(void) {
int x=0,f=1; char c=getchar();
for (;!isdigit(c);c=getchar()) if (c=='-') f=-1;
for (;isdigit(c);c=getchar()) x=x*10+c-'0';
return x*f;
}
int cmp(double a) {
if (fabs(a)<EPS) return 0;
return a<0?-1:1;
}
int Check(double xn,double yn) {
rep(i,2,n) {
double t=det(p[i-1]-point(xn,yn),p[i]-point(xn,yn));
if (cmp(t)<0) return 0;
}
return 1;
}
int InBorder(double xn,double l,double r) {
return cmp(xn-l)>=0&&cmp(r-xn)>=0;
}
double Solve(double xn) {
double l=0,r=MAX;
while (cmp(r-l)>0) {
double mid=(l+r)/2;
if (Check(xn,mid))
r=mid;
else l=mid;
}
double bsH;
rep(i,1,n-1)
if (InBorder(xn,p[i].x,p[i+1].x)) {
double k=(p[i+1].y-p[i].y)/(p[i+1].x-p[i].x),b=p[i].y-k*p[i].x;
bsH=k*xn+b;
break;
}
return l-bsH;
}
double RandFloat(void) {
return rand()%1000/1000.0;
}
double SA(void) {
now=(p[1].x+p[n].x)/2.0;
nd=Solve(now);
double res=nd;
for (double tem=p[n].x-p[1].x;tem>END;tem*=SPEED) {
double nx=now+tem*(RandFloat()*2-1);
if (!InBorder(nx,p[1].x,p[n].x)) continue;
double nxd=Solve(nx); double slack=RandFloat();
if (cmp(nxd-nd)<0||cmp(tem-slack)>0) {
now=nx;
nd=nxd;
res=min(res,nxd);
}
}
return res;
}
int main(void) {
#ifndef ONLINE_JUDGE
freopen("bzoj1038.in","r",stdin);
freopen("bzoj1038.out","w",stdout);
#endif
srand(19980406);
n=rd();
rep(i,1,n) p[i].x=rd();
rep(i,1,n) p[i].y=rd();
ans=MAX;
rep(tms,1,T) {
double t=SA();
ans=min(ans,t);
}
printf("%0.3lf\n",ans);
return 0;
}
分析2:三分法
对于一条线段,上面的点的答案必然是单峰的。
证明略,自己画个图YY去吧。
有一篇题解:http://blog.csdn.net/Fuxey/article/details/50528819
分析3:半平面交
http://blog.csdn.net/regina8023/article/details/43935773
【bzoj1038】瞭望塔的更多相关文章
- BZOJ1038 瞭望塔
学习了半平交面. 我这里写的是训练指南中的双端队列,每次判断是否删去更优然后更新. 看hzwer中有一处不太明白就是为何要将两段加入队列 后来对拍出错才知道是因为精度,当两线重合时他们叉积返回值是一个 ...
- 【BZOJ1038】[ZJOI2008]瞭望塔 半平面交
[BZOJ1038][ZJOI2008]瞭望塔 Description 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安.我们将H村抽象为一维的轮廓.如 ...
- bzoj1038: [ZJOI2008]瞭望塔
Description 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安.我们将H村抽象为一维的轮廓.如下图所示 我们可以用一条山的上方轮廓折线(x1, ...
- bzoj千题计划126:bzoj1038: [ZJOI2008]瞭望塔
http://www.lydsy.com/JudgeOnline/problem.php?id=1038 本题可以使用三分法 将点按横坐标排好序后 对于任意相邻两个点连成的线段,瞭望塔的高度 是单峰函 ...
- 【bzoj1038】瞭望塔 半平面交
题目描述 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安.我们将H村抽象为一维的轮廓.如下图所示 我们可以用一条山的上方轮廓折线(x1, y1), ( ...
- 【BZOJ1038】【ZJOI2008】瞭望塔 [模拟退火]
瞭望塔 Time Limit: 10 Sec Memory Limit: 162 MB[Submit][Status][Discuss] Description 致力于建设全国示范和谐小村庄的H村村 ...
- 「BZOJ1038」「洛谷P2600」「ZJOI2008」瞭望塔 半平面交+贪心
题目链接 BZOJ/洛谷 题目描述 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安. 我们将H村抽象为一维的轮廓.如下图所示: 我们可以用一条山的上方 ...
- [BZOJ1038][ZJOI2008]瞭望塔(半平面交)
1038: [ZJOI2008]瞭望塔 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2999 Solved: 1227[Submit][Statu ...
- 刷题总结——瞭望塔(bzoj1038)
题目: Description 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安.我们将H村抽象为一维的轮廓.如下图所示 我们可以用一条山的上方轮廓折线 ...
随机推荐
- Struts2的处理结果(二)——处理结果的类型
Struts2的处理结果(二) --处理结果的类型 1.Struts2內建的支持的结果类型: 在<result>元素中的type属性,确定了结果类型. chain:Action链式处理的结 ...
- 获取某个数据所在数据列表中的行数 mysql
select * from (select @rownum := @rownum+1 as rownum,goods_idfrom table_goods, (select @rownum:=0) t ...
- 向sql server 导入数据库
在sql server 中选择数据库.右键,还原数据库 选择源设备,点击添加,选中相应的数据库文件. 在目标数据库栏选择相应的数据库名称 点击下一步.
- 【转载】.NET程序员走向高端必读书单汇总
原文:.NET程序员走向高端必读书单汇总 .NET程序员走向高端必读书单汇总 一.知识树 1. 基本能力 1.1 数学 1.2 英语 1.3 语言表达 2. 计算机组织与体系结构 3. 算法与数据结构 ...
- Beaglebone Black - 准备
首先要玩 BBB,你需要买一台 BBB,淘宝 Element14 Beaglebone Black,我购入价 RMB 310,带数据线,没电源适配器的.Seeedstudio 有台叫 Beaglebo ...
- mysql启动关闭
RedHat Linux (Fedora Core/Cent OS) 1.启动:/etc/init.d/mysqld start2.停止:/etc/init.d/mysqld stop3.重启:/et ...
- SQL语句like子句中的转义符
如果想在SQL LIKE里查询有下划线'_'或是'%'等值的记录,直接写成like 'XXX_XX',则会把'_'当成是like的通配符.SQL里提供了 escape子句来处理这种情况,escape可 ...
- SQL疑难杂症【1】解决SQL2008 RESTORE 失败问题
有时候从服务器或者其它电脑上面备份的数据库文件在还原到本地的时候会出现以下错误: 这种情况通常是备份文件之前的逻辑名称跟当前的名称对应不上,我们可以通过以下语句查看备份文件的逻辑名称: 知道备份文件 ...
- python_way ,day11 线程,怎么写一个多线程?,队列,生产者消费者模型,线程锁,缓存(memcache,redis)
python11 1.多线程原理 2.怎么写一个多线程? 3.队列 4.生产者消费者模型 5.线程锁 6.缓存 memcache redis 多线程原理 def f1(arg) print(arg) ...
- phpcms 在后台增加了一个模型的话,在数据库中就会相应的增加数据库表
在phpcms后台管理系统中,我们如果增加一个新的模型的话,例如名为:测试模型,英文名:test 在添加完成后,我们在数据库中发现增加了两个数据表:v9_test,v9_test_data;