题目描述

  小$w$伤心的走上了$Star\ way\ to\ heaven$。
  到天堂的道路是一个笛卡尔坐标系上一个$n\times m$的长方形通道(顶点在$(0,0)$和$(n,m)$),小$w$从最左边任意一点进入,从右边任意一点走到天堂。
  最左最右的距离为$n$,上下边界距离为$m$。
  其中长方形内有$k$个$Star$,每个$Star$都有一个整点坐标,$Star$的大小可以忽略不计。
  每个$Star$以及长方形上下两个边缘(宇宙的边界)都有引力,所以为了成功到达$heaven$小$w$离他们越远越好。
  请问小$w$走到终点的路径上,距离所有星星以及宇宙的边界的最小距离最大值可以为多少?


输入格式

一行三个整数$n,m,k$。
接下来$k$行,每行两个整数$x_i,y_i$表示一个点的坐标。


输出格式

一行一个整数表示答案,绝对误差不能超过${10}^{-6}$。


样例

样例输入:

10 5 2
1 1
2 3

样例输出:

1.11803399


数据范围与提示

对于$20\%$的数据,$k\leqslant 10$。
对于$50\%$的数据,$k\leqslant 400$。
对于$80\%$的数据,$k\leqslant 1,000$。
对于$100\%$的数据,$k\leqslant 6,000,n,m\leqslant {10}^6$。


题解

先来重申一下题意(考试的时候没弄明白,当场爆炸),路径不一定直的,中途可以拐弯(我也不知道为什么我考试的时候会下意识以为路径一定是直的)。

明确完了,开始讲题。

首先,我们如果要从两个$Star$之间穿过,那么选择从它们的中点穿过一定不劣,所以我们的问题就转化为了找从左边到右边所有路径中所要穿过的$Star$中离的最近的两个的最大值(语文不好,见谅),这个东西类似于[NOIP模拟测试]:$water$(BFS)这道题,但是当时我是使用$BFS$直接$A$掉的,其实正解就是最小生成树,那么这道题我们也用最小生成树。

怎么利用最小生成树呢?

首先是建图,先将所有的$Star$相互连边,然后再将最靠上的一个点连向上边界,最靠下的一个点连向下边界。

然后我们考虑怎么利用最小生成树,我们要从左边到右边,也就要穿过在最小生成树中从上边界到下边界最短路径中的一条边,而最优策略一定是走最长的那一条边,所以整道题便转化为了找最小生成树中从上边界到下边界的最短路径中的最长边,答案极为这条边边长的一半。

但是我们这里需要注意的是空间问题,显然$Kruskal$算法在稠密图中的空间复杂度高的可怕,而这道题考的我们便是对$Prim$算法的利用,所以有的不常用的算法至少还是要知道其原理的。

下面代码比较清奇,我在$prim$算法上稍作了改动,代码复杂度大幅度减小。

时间复杂度:$\Theta(n^2)$。

期望得分:$100$分。

实际得分:$100$分。


代码时刻

#include<bits/stdc++.h>
using namespace std;
int n,m,k;
double x[7000],y[7000];
double dis[7000];
bool vis[7000];
double ans;
int main()
{
dis[0]=20020923;
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=k;i++)
{
scanf("%lf%lf",&x[i],&y[i]);
dis[i]=m-y[i];
}
dis[k+1]=m;
while(1)
{
int flag=0;
for(int i=1;i<=k+1;i++)
if(!vis[i]&&dis[i]<dis[flag])flag=i;
vis[flag]=1;
ans=max(ans,dis[flag]);
if(flag==k+1)break;
for(int i=1;i<=k;i++)
dis[i]=min(dis[i],sqrt((x[i]-x[flag])*(x[i]-x[flag])+(y[i]-y[flag])*(y[i]-y[flag])));
dis[k+1]=min(dis[k+1],y[flag]);
}
printf("%.8lf",ans/2);
return 0;
}

rp++

[CSP-S模拟测试]:Star Way To Heaven(最小生成树Prim)的更多相关文章

  1. 7.15考试总结(NOIP模拟16)[Star Way To Heaven·God Knows·Lost My Music]

    败者死于绝望,胜者死于渴望. 前言 一看这个题就来者不善,对于第一题第一眼以为是一个大模拟,没想到是最小生成树. 对于第二题,先是看到了状压可以搞到的 20pts 然后对着暴力一顿猛调后来发现是题面理 ...

  2. NOIP模拟测试24「star way to hevaen·lost my music」

    star way to heaven 题解 大致尝试了一下并查集,记忆化搜索,最小生成树 最小生成树是正解,跑最小生成树然后找到最大的值 欧几里德距离最小生成树学习 prim楞跑 至于为什么跑最小生成 ...

  3. NOIP模拟16:「Star Way To Heaven·God Knows·Loost My Music」

    T1:Star Way To Heaven 基本思路:   最小生成树.   假如我们将上边界与下边界看作一个点,然后从上边界经过星星向下边界连边,会发现,他会形成一条线将整个矩形分为左右两个部分. ...

  4. 0817NOIP模拟测试赛后总结

    吐槽一句:话说NOIP都取消了还叫NOIP模拟真的好么 于是乎我再次爆炸……(0+20+50=70 rank26) 赛时状态 赛时的状态依旧不佳.不过还是硬逼着自己把三道题都读完,然后开始对出题人静坐 ...

  5. Android单元测试与模拟测试详解

    测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...

  6. [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)

    目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...

  7. 安装nginx python uwsgi环境 以及模拟测试

    uwsgi帮助文档: http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html http://uwsgi-docs.re ...

  8. 利用Python中的mock库对Python代码进行模拟测试

    这篇文章主要介绍了利用Python中的mock库对Python代码进行模拟测试,mock库自从Python3.3依赖成为了Python的内置库,本文也等于介绍了该库的用法,需要的朋友可以参考下     ...

  9. 转 C#实现PID控制的模拟测试和曲线绘图

    C#实现PID控制的模拟测试和曲线绘图   本文分两部分,一部分是讲PID算法的实现,另一部分是讲如何用动态的曲线绘制出PID运算的结果. 首先,PID算法的理论模型请参考自动控制理论,最早出现的是模 ...

随机推荐

  1. CET-6 分频周计划生词筛选(番外篇:百词斩)

    点我阅读 番外-百词斩 2016.09.18 12:00pm transverse counterpart accessory cult gorgeous sediment assimilate st ...

  2. 题解[SCOI2009]粉刷匠 难度:省选/NOI-

    Description windy有 N 条木板需要被粉刷.每条木板被分为 M 个格子.每个格子要被刷成红色或蓝色.windy每次粉刷,只能选择一条木板上一段连续的格子,然后涂上一种颜色.每个格子最多 ...

  3. 【python】随机数相关

    http://www.cnblogs.com/yd1227/archive/2011/03/18/1988015.html 该博文写的很详细,备忘. 需要注意的是,写测试脚本的时候,不要将脚本命名成跟 ...

  4. sql server 2008查询时报错,消息:8155,没有为'a'的列2指向任何列

    解决方法1: 关掉Sql Server再打开, 重新查询 解决方法2: select T.* from(   select row_number() over(order by age desc) a ...

  5. daily plan -- 2019/5/20

    1.课内作业:物联网工程导论论文. 2.实验项目计划:学习Kinect彩色帧读取. 3.算法:LeetCode 动态规划一题. 4.英语:听力30分钟训练,英语单词. 今日心情: 进度反馈:计划基本完 ...

  6. [暑假集训Day3T1]小木棍

    经典搜索题. 考虑以下9种优化 1)按木棍长度排序,使得较大长度的木棍被较早的选出. 2)只找能够整除的木棍长度,因为不能被sum整除一定不会出整数根,自然也就不是最优解. 3)枚举木棍长度时只需从最 ...

  7. 【问题解决方案】Mathtype中丢失Mplugin.dll的问题

    网络上搜索到的答案: Mathtype中丢失Mplugin.dll,把Mplugin.dll文件放到Mathtype安装根目录下就好了. 然而试过以后仍然不行 事实是: 如果下载的mathtype安装 ...

  8. 从“中产梦”中醒来,好好打工吧

    "中产"定义 自打"中产阶级/阶层"概念出现,总有人试图给出定义.搞不清何为"中产"却试图定义"中产阶级/阶层",注定是 ...

  9. IDEA中web项目maven项目手动打war包的方式

    手动打包 https://blog.csdn.net/ibigboy/article/details/90287963 tomcat部署web项目方法 https://www.cnblogs.com/ ...

  10. 关于Jenkins的网站及其他学习的网站

    配置efk https://www.cnblogs.com/fzxiaomange/p/efk-getstart.html https://blog.csdn.net/wangmuming/artic ...