The  Boy Next   Doors

题意:给定一个固定大小的房间($x,y$的范围都是$[0,10]$),有$n$个墙壁作为障碍(都与横坐标轴垂直),每个墙壁都有两扇门分别用四个点来描述,起点终点固定在$(0,5)$和$(10,5)$,求起点到终点的最短路长度,$n<=18$


题解:

我们把每堵墙的每一“段”作为一条线段,对任意两点$u,v$,如果两点间的连线不和其他线段相交,那我们从$u$走到$v$的最短距离就是他们的欧几里得距离,对所有点对都这么做一遍,处理出所有能够直接到达的点之间的距离

如果不能直接从$u$到$v$,那么既然是最短路,那走直线一定比走曲线要好,也就是一定是经过他们中间的某些点然后到达的,然后对所有点跑一次最短路就好了

这题范围很小Floyd也能过…

  1 #include<cstdio>
2 #include<cmath>
3 #include<cstring>
4 #include<algorithm>
5 using namespace std;
6
7 const double precision=10e-6;
8
9 const double INF=(~0u>>2);
10
11 const int N=105;
12
13 struct Point
14 {
15 double x,y;
16 }p[N];
17
18 struct Line
19 {
20 Point a,b;
21 }l[N];
22
23 int n,cnt_point,cnt_line;
24
25 double dist[N][N];
26
27 inline int dblcmp(double d)
28 {
29 if(fabs(d)<precision)
30 return 0;
31 return (d>0?1:-1);
32 }
33
34 inline double det(double x1,double y1,double x2,double y2)
35 {
36 return x1*y2-x2*y1;
37 }
38
39 inline double cross(Point a,Point b,Point c)
40 {
41 return det(b.x-a.x,b.y-a.y,c.x-a.x,c.y-a.y);
42 }
43
44 inline bool SegCrossSimple(Point a,Point b,Point c,Point d)
45 {
46 return (dblcmp(cross(c,a,b))^dblcmp(cross(d,a,b)))==-2&&(dblcmp(cross(a,c,d))^dblcmp(cross(b,c,d)))==-2;
47 }
48
49 inline double sqr2(double x)
50 {
51 return x*x;
52 }
53
54 inline double dis(int i,int j)
55 {
56 return sqrt(sqr2(p[i].x-p[j].x)+sqr2(p[i].y-p[j].y));
57 }
58
59 inline void addPoint(double x,double y)
60 {
61 p[++cnt_point]=(Point){x,y};
62 }
63
64 inline void addLine(double x1,double y1,double x2,double y2)
65 {
66 l[++cnt_line]=(Line){(Point){x1,y1},(Point){x2,y2}};
67 }
68
69 inline void init()
70 {
71 memset(p,0,sizeof(p));
72 memset(l,0,sizeof(l));
73 cnt_point=cnt_line=0;
74 addPoint(0,5);addPoint(10,5);
75 }
76
77 inline void solve()
78 {
79 init();
80
81 double x,y1,y2,y3,y4;
82 for(register int i=1;i<=n;i++)
83 {
84 scanf("%lf%lf%lf%lf%lf",&x,&y1,&y2,&y3,&y4);
85 addPoint(x,y1);addPoint(x,y2);
86 addPoint(x,y3);addPoint(x,y4);
87 addLine(x,0,x,y1);addLine(x,y2,x,y3);addLine(x,y4,x,10);
88 }
89
90 for(register int i=1;i<=cnt_point;i++)dist[i][i]=0;
91
92 for(register int i=1;i<=cnt_point;i++)
93 {
94 for(register int j=i+1;j<=cnt_point;j++)
95 {
96 bool flag=1;
97 for(register int k=1;k<=cnt_line;k++)
98 {
99 if(SegCrossSimple(p[i],p[j],l[k].a,l[k].b))
100 {
101 flag=0;
102 break;
103 }
104 }
105 if(flag)
106 dist[i][j]=dis(i,j);
107 else
108 dist[i][j]=INF;
109
110 dist[j][i]=dist[i][j];
111 }
112 }
113
114 for(register int k=1;k<=cnt_point;k++)
115 for(register int i=1;i<=cnt_point;i++)
116 for(register int j=1;j<=cnt_point;j++)if(dist[i][k]!=INF&&dist[k][j]!=INF)
117 dist[i][j]=min(dist[i][j],dist[i][k]+dist[k][j]);
118
119 printf("%.2lf\n",dist[1][2]);
120 }
121
122 int main()
123 {
124 while(scanf("%d",&n)==1)
125 {
126 if(n==-1)break;
127 solve();
128 }
129 return 0;
130 }

[日常摸鱼]UVA393 The Doors 简单计算几何+最短路的更多相关文章

  1. ●POJ 1556 The Doors(简单计算几何+最短路)

    ●赘述题目 10*10的房间内,有竖着的一些墙(不超过18个).问从点(0,5)到(10,5)的最短路. 按照输入样例,输入的连续5个数,x,y1,y2,y3,y4,表示(x,0--y1),(x,y2 ...

  2. [日常摸鱼]bzoj1502[NOI2005]月下柠檬树-简单几何+Simpson法

    关于自适应Simpson法的介绍可以去看我的另一篇blog http://www.lydsy.com/JudgeOnline/problem.php?id=1502 题意:空间里圆心在同一直线上且底面 ...

  3. Hash 日常摸鱼笔记

    本篇文章是Hash在信息学竞赛中的应用的学习笔记,分多次更新(已经有很多坑了) 一维递推 首先是Rabin-Karp,对于一个长度为\(m\)的串\(S\) \(f(S)=\sum_{i=1}^{m} ...

  4. [日常摸鱼]HDU1724 Ellipse-自适应Simpson法

    模板题~ QAQ话说Simpson法的原理我还是不太懂-如果有懂的dalao麻烦告诉我~ 题意:每次给一个椭圆的标准方程,求夹在直线$x=l$和$x=r$之间的面积 Simpson法 (好像有时候也被 ...

  5. [日常摸鱼]bzoj3224普通平衡树-Treap、Splay、01Trie、替罪羊树…

    http://www.lydsy.com/JudgeOnline/problem.php?id=3224 经典的平衡树模板题-各种平衡树好像都可以(黄学长之前好像还用vector卡过了这题) 所以这篇 ...

  6. [日常摸鱼]bzoj1257余数之和

    题意:输入$k,n$,求$\sum_{i=1}^n k \mod i$ $k \mod i=k-i*\lfloor \frac{k}{i} \rfloor $,$n$个$k$直接求和,后面那个东西像比 ...

  7. [日常摸鱼]bzoj1001狼抓兔子-最大流最小割

    题意就是求最小割- 然后我们有这么一个定理(最大流-最小割定理 ): 任何一个网络图的最小割中边的容量之和等于图的最大流. (下面直接简称为最大流和最小割) 证明: 如果最大流>最小割,那把这些 ...

  8. [日常摸鱼]pojKaka's Matrix Travels-拆点+最大费最大流

    方格取数的升级版,每个格子最多取一次. $k=1$的话就是个普及组的dp题,$k=2$就是在之前的基础上多加两维. 然而现在$k$太大了当然就不dp啦 对于$k=1$的情况我们还可以把$(i,j)$向 ...

  9. [日常摸鱼]loj6000「网络流 24 题」搭配飞行员

    题面 应该是二分图匹配,不过我写的是网络最大流. dinic求二分图最大匹配:加个源点和汇点,源点连向二分图的一边所有点,二分图的另一边所有点连向汇点,很明显这样得到的最大流就是这个二分图的最大匹配. ...

随机推荐

  1. MindManager使用教程:如何导出HTML5交互式导图

    Mindmanager思维导图软件有着友好的用户界面以及丰富的思维导图制作功能.再搭配与Microsoft 软件的无缝集成功能,使得这款思维导图软件越来越受到职场人士的喜爱. 不仅是作为制作思维导图的 ...

  2. Guitar Pro小课堂之如何演奏刮弦

    每当我们听到吉他现场演出的时候,看到吉他手在激烈的刮弦时,都觉得很酷,非常有感染力.刮弦在我们弹吉他或编曲时,会经常用到,虽然时间很短,但会为你加分不少. 那么我们应该如何演奏刮弦呢,我们先用E5和弦 ...

  3. 如何用思维导图软件MindManager制作项目管理图表

    项目管理的官方解释为:运用各种相关技能.方法与工具,为满足或超越项目有关各方对项目的要求与期望,所开展的各种计划.组织.领导.控制等方面的活动. 其实使用MindManager思维导图软件来创建项目管 ...

  4. 使用Camtasia制作冰雪奇缘视频

    冰雪奇缘的精良制作,以及场景的华丽,让很多女孩子都很喜欢.对于其中美丽的冰雪场景,我们还可以使用Camtasia(Windows系统)教程录制软件来做冰雪奇缘视频. Camtasia教程录制软件是一款 ...

  5. 教你在CorelDRAW中制作水印

    水印是一种数字保护的手段,在图像上添加水印即能证明本人的版权,还能对版权的保护做出贡献.也就是在图片上打上半透明的标记,因其具有透明和阴影的特性,使之不管在较为阴暗或明亮的图片上都能完美使用,嵌入的水 ...

  6. FL Studio录制面板作用介绍

    在上一节教程中我们详细的讲解了一下FL Studio录制面板菜单的一些功能,今天我们将继续讲解该面板的知识.具体内容小编这里就不多说了,还是一起来看看吧! 1.录音倒数.该按钮在打开的情况下会在录音前 ...

  7. 关于iOS路径变化的解决方案

    问题描述: 使用沙盒存储文件的时候,我们会保存文件的绝对路劲以便下次读取,但是发现一个现象,我们保存的文件,在第二次打开App去查找的时候,发现找不到了...... 查找原因: iOS8之后,苹果添加 ...

  8. 执行文件异常报错:ImportError: attempted relative import with no known parent package

    这个问题困扰了我很久了,网上的解决方法都很一致,找来找去都是一样的解决方法,在导入包的文件和执行文件加入 1 print('__file__={0:<35} | __name__={1:< ...

  9. window consul安装和运行

    consul 前言 一.consul是什么? 二.使用步骤 1.安装 2.启动 结束~~ 前言 刚开始接触spring cloud,其中就有用到consul,简单介绍一下以及怎么安装运行起来 提示:以 ...

  10. P5665 划分

    Part 1 先来看一个错误的贪心做法:假设当前结尾的一段和为 \(a\),等待加入结尾的一段和为 \(b\),现在要处理新进来的数 \(c\). \(a\leq b\),将 \(a\) 算入答案,将 ...