P2498 [SDOI2012]拯救小云公主

题目描述

英雄又即将踏上拯救公主的道路……

这次的拯救目标是——爱和正义的小云公主。

英雄来到\(boss\)的洞穴门口,他一下子就懵了,因为面前不只是一只\(boss\),而是上千只\(boss\)。当英雄意识到自己还是等级1的时候,他明白这就是一个不可能完成的任务。

但他不死心,他在想,能不能避开\(boss\)去拯救公主呢,嘻嘻。

\(Boss\)的洞穴可以看成一个矩形,英雄在左下角\((1,1)\),公主在右上角(row,line)\(。英雄为了避开\)boss\(,当然是离\)boss\(距离越远越好了,所以英雄决定找一条路径使到距离\)boss$的最短距离最远。

Ps:英雄走的方向是任意的。

你可以帮帮他吗?

当英雄找到了美丽漂亮的小云公主,立刻就被\(boss\)包围了!!!英雄缓闭双眼,举手轻挥,白光一闪后使用了回城卷轴,回到了城堡,但只有小云公主回去了……因为英雄忘了进入回城的法阵了。

输入输出格式

输入格式:

第一行,输入三个整数,\(n\)表示\(boss\)的数目,\(row\),\(line\)表示矩形的大小;

接下来\(n\)行,每行分别两个整数表示\(boss\)的位置坐标。

输出格式:

输出一个小数,表示英雄的路径离\(boss\)的最远距离,精确到小数点后两位。


感觉这题好神,没见过模型的话。

70pts:

二分答案最远距离,并查集维护boss所在圆是否连通。

复杂度:\(O(log?N^2)\)

期望得分:70 实际得分:70~100

100pts:

(1) 最小生成树

这样去看,英雄通过这个平面图,实际上只有两种类型。

一是穿过个两个boss之间的地方,这时我们走两个boss之间最中间的地方是最划算的。

二是穿过边界和boss之间的地方,这时我们贴着边界走是最划算的。

我们有很多个这样的地方可以走,走哪些我们可以确定既可以穿过去所有的boss又能使它距离我们最远呢?

如果我们把这些点(包括边界抽象出来的点)连成一条链

我们可以选择一个最优的方案,从中间穿过去

然而仔细想想,如果通过了另外的两点比最大距离还小的点,那不就废了吗?

换一种角度理解好了

按照\(kruskal\)的方法,我们一个一个从小到大加边

当上面的边和下面的边所代表的虚点(实际上有四种情况)连通时,我们就不得不对这条链(实际形态应该是树的连接两个虚点的链)上的某一边做出选择了,这时候我们选择之中最大的走,也不会遇到更小的两点距离了

注意如果是boss和Boss之间的边权要除2(走中间)

然而这个题只可以用prim算法(稠密图)

复杂度:\(O(N^2)\)

期望得分:100 实际得分:100

(2) SPFA

实质上SPFA也只是求得了这条在最小生成树上的最大边的权值。

我们跑0点到n+1点(两个虚点)之间的每条路径上最长的边其中的最小值

注意松弛目的是最小值,但松弛时是从前面的边的最小值和当前边选出一个最大的

复杂度:\(O(N^2)\) (建图)

期望得分:100 实际得分:100

贴一下SPFA的代码吧

#include <cstdio>
#include <cmath>
#include <queue>
double min(double x,double y){return x<y?x:y;}
double max(double x,double y){return x>y?x:y;}
const int N=3050;
double g[N][N],dis[N],x[N],y[N],n,m;
int num,used[N];
double get(double x1,double y1,double x2,double y2)
{
return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2))/2;
}
void init()
{
scanf("%d%lf%lf",&num,&n,&m);
for(int i=1;i<=num;i++)
scanf("%lf%lf",x+i,y+i);
for(int i=1;i<=num;i++)
for(int j=i+1;j<=num;j++)
g[i][j]=g[j][i]=get(x[i],y[i],x[j],y[j]);
for(int i=1;i<=num;i++)
{
g[0][i]=g[i][0]=min(x[i]-1,m-y[i]);
g[i][num+1]=g[num+1][i]=min((n-x[i]),y[i]-1);
}
g[0][num+1]=g[num+1][0]=1e233;
dis[0]=0;
for(int i=1;i<=num+1;i++)
dis[i]=1e233;
}
void spfa()
{
std::queue <int > q;
q.push(0);
while(!q.empty())
{
int u=q.front();
q.pop();used[u]=0;
for(int i=1;i<=num+1;i++)
{
if(i==u) continue;
if(dis[i]>max(dis[u],g[u][i]))
{
dis[i]=max(dis[u],g[u][i]);
if(!used[i])
{
used[i]=1;
q.push(i);
}
}
}
}
}
int main()
{
init();
spfa();
printf("%.2lf",dis[num+1]);
return 0;
}

2018.7.12

洛谷 P2498 [SDOI2012]拯救小云公主 解题报告的更多相关文章

  1. 洛谷P2498 [SDOI2012]拯救小云公主 【二分 + 并查集】

    题目 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意识到自己还是等级1 ...

  2. P2498 [SDOI2012]拯救小云公主

    \(\color{#0066ff}{ 题目描述 }\) 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只bos ...

  3. 二分+并查集【bzoj3007】[SDOI2012]拯救小云公主

    Description 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意 ...

  4. [SDOI2012]拯救小云公主

    题解: 是一个不错的题目 首先我们可以考虑二分答案 然后变成判定性问题 对于每个画一个圆 当其会被阻断时就是答案 阻断有四种情况 左下 上下 左右 右上 但是这样是n^2a(n)*logn的 考虑直接 ...

  5. BZOJ 3007 [SDOI2012]拯救小云公主 - 对偶图 + 并查集

    Solution 答案具有单调性, 显然可以二分答案. 有两个注意点 : 英雄是可以随便走的, 也就是不是网格图... 还有坐标不能小于$1$ QAQ 开始时英雄在左下角, 公主在右上角, 我们反过来 ...

  6. 【BZOJ】【3007】拯救小云公主

    思路题 我的naive的做法是二分答案+判定是否有路径可走……但是没有正确理解[走的方向任意]这句话…… 其实就是说想咋走咋走= =360°无死角乱走…… 所以其实是个平面上的问题…… 我们可以换个方 ...

  7. BZOJ:4219: 跑得比谁都快 3007: 拯救小云公主

    4219: 跑得比谁都快 3007: 拯救小云公主 三角剖分的解释可以看这里:http://www.cnblogs.com/Enceladus/p/6706444.html 后一道是前一道的弱化版. ...

  8. 【BZOJ3007】拯救小云公主 二分+几何+对偶图

    [BZOJ3007]拯救小云公主 Description     英雄又即将踏上拯救公主的道路……     这次的拯救目标是——爱和正义的小云公主.     英雄来到boss的洞穴门口,他一下子就懵了 ...

  9. bzoj3007: 拯救小云公主

    Description     英雄又即将踏上拯救公主的道路……     这次的拯救目标是——爱和正义的小云公主.     英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是 ...

随机推荐

  1. python开发ftp服务器第一天(pyftpdlib)

    学习了大约快一个月的python,现在开始有意识做一些项目.(我的新书<Python爬虫开发与项目实战>出版了,大家可以看一下样章) 据我了解,python现在更多的是用于自动化运维方面, ...

  2. 真香!iOS云真机全新上线!

    WeTest 导读 众多开发者已经渐渐适应通过调用线上的安卓真机进行远程调试,但是针对iOS设备,则依然存在“iOS设备昂贵”“无法及时采购iOS最新设备”“无法复现iOS历史系统版本”等问题. 为了 ...

  3. 一步步带你配置IIS(包括错误分析)

    今天趁着工作中的问题一下子来解决IIS配置 发布网站:点击VS发布网站 第一步:新建配置文件(我取名为webSite) : 第二步:选择发布方法并且选择把文件发布到哪里(比喻在D盘创建一个文件夹web ...

  4. [.NET] 使用HttpClient操作HFS (HTTP File Server)

    前言 本篇文章介绍如何使用HttpClient操作HFS (HTTP File Server),为自己留个纪录也希望能帮助到有需要的开发人员.关于HTTP File Server的介绍.安装.设定,可 ...

  5. WebGL树形结构的模型渲染流程

    今天和大家分享的是webgl渲染树形结构的流程.用过threejs,babylonjs的同学都知道,一个大模型都是由n个子模型拼装而成的,那么如何依次渲染子模型,以及渲染每个子模型在原生webgl中的 ...

  6. 算法笔记(c++)-使用递归函数逆序一个栈

    ---恢复内容开始--- 使用递归函数逆序一个栈 题目:使用递归函数,不借助其他数据结构逆序一个栈. 我的思路:使用递归函数保存栈中变量. 递归函数分两个,一个获取并移除栈底元素,另一个负责逆序.其实 ...

  7. 《Learning scikit-learn Machine Learning in Python》chapter1

    前言 由于实验原因,准备入坑 python 机器学习,而 python 机器学习常用的包就是 scikit-learn ,准备先了解一下这个工具.在这里搜了有 scikit-learn 关键字的书,找 ...

  8. AutoCAD 自动管理字体插件[使用ObjectARX C++]

    概述: 使用AutoCAD的过程中,我们常常因为缺失字体而烦恼,本插件就是为了解决这个问题. 插件采用WEB服务器 + CAD插件方式.WEB服务器使用Python编写,部署在百度BAE上:CAD插件 ...

  9. Java:重写equals()和hashCode()

    Java:重写equals()和hashCode() 1.何时需要重写equals() 当一个类有自己特有的“逻辑相等”概念(不同于对象身份的概念). 2.设计equals() [1]使用instan ...

  10. winform default模式下和英文模式下 修改问题

    1.修改控件大小.位置等属性在default模式下修改: 2.修改控件属性最好不要做鼠标拖动放大,拖动修改位置等,建议用属性栏中的数字来改变.