[日常摸鱼]bzoj1038 [ZJOI2008]瞭望塔-模拟退火/几何
题意:给一条平面内$n$个点的折线,要求在折线上搞一个高度$h$的瞭望塔,能够看见折线上所有的点,求$h$的最小值($n \leq 300$)
updata2018.1.21
正解半平面交在另一篇里面…
updata2018.1.5
我发现这题可以随便乱搞过掉…(雾
把所有折线段的$n$条直线求出来,求他们两两之间的交点(这些交点也包括了折线上的折点)和两端的横坐标丢到一个数组$q[]$
答案的横坐标一定在$q[]$里(如果答案在某两个之间的话一定不会更优)
时间复杂度$O(n^3)$…相当暴力
INF不要开小…啧啧啧
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std; const int N=305;
struct line
{
double k,b;
line(){}
void calc(double x1,double y1,double x2,double y2)
{
k=(y1-y2)/(x1-x2);
b=y1-k*x1;
}
double f(double x)
{
return k*x+b;
}
}ls[N];
int n,tot;
double xs[N],ys[N],q[N*N],ans;
inline double high(double x)
{
double res=0;
for(register int i=1;i<n;i++)res=max(res,ls[i].f(x));
return res;
}
inline double f(double x)
{
for(register int i=1;i<n;i++)if(xs[i]<=x&&x<=xs[i+1])return ls[i].f(x);
return 0;
}
int main()
{
scanf("%d",&n);ans=1e11;
for(register int i=1;i<=n;i++)scanf("%lf",&xs[i]);
for(register int i=1;i<=n;i++)scanf("%lf",&ys[i]);
for(register int i=1;i<n;i++)ls[i].calc(xs[i],ys[i],xs[i+1],ys[i+1]);
for(register int i=1;i<n;i++)
{
for(register int j=i+1;j<n;j++)if(ls[i].k!=ls[j].k)
{
double x=(ls[j].b-ls[i].b)/(ls[i].k-ls[j].k);
if(xs[1]<=x&&x<=xs[n])q[++tot]=x;
}
}q[++tot]=xs[1];q[++tot]=xs[n];
for(register int i=1;i<=tot;i++)if(q[i]!=q[i-1])
{
double cur=fabs(high(q[i])-f(q[i]));
ans=min(ans,cur);
}printf("%.3lf",ans);
return 0;
}
跑得比之前写的不知道快到哪里去了
原文
听说正解平面半交,我不会啊做怎么办,Po姐教你模拟退火搞233
模拟退火随机横坐标,在纵坐标上二分高度
T_T然后注意细节不要写挂
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
using namespace std;
const int N=305;
struct point
{
double x,y;
point(){}
point(double tx,double ty)
{
x=tx;y=ty;
}
}ps[N];
inline point operator -(point a,point b)
{
return point(a.x-b.x,a.y-b.y);
}
struct line
{
point p1,p2;
double k,b;
void calc()
{
point p=p1-p2;
k=p.y/p.x;
b=p2.y-k*p2.x;
}
}ls[N];
int n;
double now,ansx,ansy; inline double Rand()
{
return (rand()%1000)/1000.0;
}
inline double f(line l,double x)
{
return l.k*x+l.b;
}
inline double f(double x)
{
for(register int i=2;i<=n;i++)
if(ls[i].p1.x<=x&&x<=ls[i].p2.x)return f(ls[i],x);
return 0;
}
inline double operator * (point p1,point p2)
{
return p1.x*p2.y-p1.y*p2.x;
}
inline bool judge(double x,double mid)
{
point p(x,mid);
for(register int i=2;i<=n;i++)
if((ps[i-1]-p)*(ps[i]-p)<0)
return 0;
return 1;
}
inline double check(double x)
{
double temp,l,r,mid;
temp=f(x);l=temp;r=1e11;
while(r-l>(1e-7))
{
mid=(l+r)/2;
if(judge(x,mid))r=mid;
else l=mid;
}
mid-=temp;
if(mid<ansy)ansx=x,ansy=mid;
return mid;
}
inline void SA()
{
double t=ps[n].x-ps[1].x;
while(t>(1e-5))
{
double temp=now+t*(Rand()*2-1);
if(temp<ps[1].x||temp>ps[n].x)continue;
double dE=check(now)-check(temp);
if(dE>0||exp(dE/t)>Rand())
now=temp;
t*=0.99;
}
t*=10;
for(register int i=1;i<=1000;i++,t*=0.99)
{
double temp=ansx+t*(Rand()*2-1);
if(temp<ps[1].x||temp>ps[n].x)continue;
check(temp);
}
}
int main()
{
//freopen("input.in","r",stdin);
//srand(19260817);
scanf("%d",&n);
for(register int i=1;i<=n;i++)scanf("%lf",&ps[i].x);
for(register int i=1;i<=n;i++)scanf("%lf",&ps[i].y);
for(register int i=2;i<=n;i++)ls[i].p1=ps[i-1],ls[i].p2=ps[i],ls[i].calc();
ansy=1e11;ansx=now=(ps[n].x-ps[1].x)/2;SA();
printf("%.3lf",ansy+(1e-7));
return 0;
}
等学了平面半交再来更新
[日常摸鱼]bzoj1038 [ZJOI2008]瞭望塔-模拟退火/几何的更多相关文章
- [日常摸鱼]bzoj1038[ZJOI2008]瞭望塔-半平面交
这回好好用半平面交写一次- 看了cls当年写的代码看了好久大概看懂了-cls太强辣 #include<cstdio> #include<iostream> #include&l ...
- [BZOJ1038][ZJOI2008]瞭望塔(半平面交)
1038: [ZJOI2008]瞭望塔 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2999 Solved: 1227[Submit][Statu ...
- bzoj千题计划126:bzoj1038: [ZJOI2008]瞭望塔
http://www.lydsy.com/JudgeOnline/problem.php?id=1038 本题可以使用三分法 将点按横坐标排好序后 对于任意相邻两个点连成的线段,瞭望塔的高度 是单峰函 ...
- bzoj1038: [ZJOI2008]瞭望塔
Description 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安.我们将H村抽象为一维的轮廓.如下图所示 我们可以用一条山的上方轮廓折线(x1, ...
- 【半平面交】bzoj1038 [ZJOI2008]瞭望塔
http://m.blog.csdn.net/blog/qpswwww/44105605 #include<cstdio> #include<cmath> #include&l ...
- BZOJ-1038 [ZJOI2008]瞭望塔
先求半平面交,然后建塔的地方肯定是在半平面交的交点上或者是在地面线段的交点上. #include <cstdlib> #include <cstdio> #include &l ...
- [日常摸鱼]bzoj1036 [ZJOI2008]树的统计Count
听说后天会考x 省选居然还考模板题的么(好吧好像NOI也有考而且也是树剖-) 题意:一棵树,每个点有权值,三种操作:单点修改.求链上最大值.求链上权值和. 直接上模板. 我可能不会写单点修改的线段树了 ...
- 【BZOJ1038】[ZJOI2008]瞭望塔 半平面交
[BZOJ1038][ZJOI2008]瞭望塔 Description 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安.我们将H村抽象为一维的轮廓.如 ...
- 【bzoj1038】瞭望塔
[bzoj1038]瞭望塔 题意 致力于建设全国示范和谐小村庄的H村村长dadzhi,决定在村中建立一个瞭望塔,以此加强村中的治安.我们将H村抽象为一维的轮廓.如下图所示 我们可以用一条山的上方轮廓折 ...
随机推荐
- guitar pro系列教程(二十六):Guitar Pro教程之虚拟吉他功能讲解
上一章节我们讲述了Guitar Pro的组织小节的相关功能,那么本章节我们还是采用图文结合的方式为大家讲解关于guitar pro中一些虚拟的吉他功能一 一做出讲解,感兴趣的朋友可以一起进来学习了解哦 ...
- mac实用软件推荐 mac好用的软件
终于入手了梦寐以求的苹果电脑,但却发现其操作系统与Windows大相径庭!不会使用怎么办?不用担心,我们可以借助软件的力量.一款实用的Mac软件不仅能够使你的工作效率显著提高,同时它还能帮助你更快地熟 ...
- 分布式监控系统之Zabbix proxy
前文我们了解了zabbix 使用snmp和jmx信道采集数据的相关使用配置,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/14029864.html:今天我们来 ...
- C Looooops POJ - 2115
数论好题.. 香! 首先我们看到这一题, 题意是 \[a + c * x \equiv b (mod \ \ 2 ^ k) \] 对此式移一下项, 得 \[c * x \equiv b - a (mo ...
- .Net Core官方的 JWT 授权验证
什么是JWT? JSON Web令牌(JWT)是一个开放标准(RFC 7519),它定义了一种紧凑且自包含的方式,用于在各方之间安全地传输信息作为JSON对象.由于此信息是经过数字签名的,因此可以被验 ...
- Spring源码解析之BeanFactoryPostProcessor(二)
上一章,我们介绍了在AnnotationConfigApplicationContext初始化的时候,会创建AnnotatedBeanDefinitionReader和ClassPathBeanDef ...
- win10下安装anaconda3+tensorflow
安装了三天终于安装成功了,今天简单写下自己的安装步骤 1.下载可以在Anaconda3官网下载:https://www.anaconda.com/products/individual 也可以通过清华 ...
- Docker中搭建FastDFS文件系统(多图)
关于FastDFS FastDFS 是以 C 语言开发的一项开源轻量级分布式文件系统,他对文件进行管理,主要功能有:文件存储,文件同步,文件访问(文件上传/下载)等,特别适合以文件为载体的在线服务,如 ...
- 【2020.11.28提高组模拟】T2 序列(array)
序列(array) 题目描述 给定一个长为 \(m\) 的序列 \(a\). 有一个长为 \(m\) 的序列 \(b\),需满足 \(0\leq b_i \leq n\),\(\sum_{i=1}^ ...
- Spring Cloud 学习 (四) Hystrix & Hystrix Dashboard & Turbine
在复杂的分布式系统中,可能有几十个服务相互依赖,这些服务由于某些原因,例如机房的不可靠性.网络服务商的不可靠性等,导致某个服务不可用 . 如果系统不隔离该不可用的服务,可能会导致整个系统不可用.Hys ...