bzoj3007 拯救小云公主
3007: 拯救小云公主
Time Limit: 5 Sec Memory Limit: 512 MB
Submit: 159 Solved: 71
[ Submit][ Status][ Discuss]
Description
Input
Output
Sample Input
2 2
输出样例1:
1.00
输入样例2:
1 3 3
3 1
输出样例2:
2.00
Sample Output
HINT
100%数据,n<=3000;
思路不错的一道题。
任意两个圆之间连边,长度为圆心距的一半。然后问题转化为,从左上两条边到右下两条边找一条路径,使得路径上的最大边最小,SPFA。
注意ans的初值是圆心到起点和终点距离的最小值。(详见程序)
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<queue>
#define F(i,j,n) for(int i=j;i<=n;i++)
#define D(i,j,n) for(int i=j;i>=n;i--)
#define ll long long
#define maxn 3005
using namespace std;
int n,nx,ny,s,t;
double ans,dis[maxn],g[maxn][maxn];
bool inq[maxn];
struct data{int x,y;}a[maxn];
const double inf=1e10;
queue<int> q;
inline int read()
{int x=0,f=1;char ch=getchar();while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}while (ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f;
}
inline double getdis(data a,data b)
{double x=a.x-b.x,y=a.y-b.y;return sqrt(x*x+y*y);
}
inline void spfa()
{F(i,1,t) dis[i]=inf;dis[s]=0;inq[s]=true;q.push(s);while (!q.empty()){int x=q.front();q.pop();inq[x]=false;F(i,1,t) if (x!=i&&max(dis[x],g[x][i])<dis[i]){dis[i]=max(dis[x],g[x][i]);if (!inq[i]) inq[i]=true,q.push(i);}}
}
int main()
{n=read();nx=read();ny=read();s=n+1;t=n+2;F(i,1,n) a[i].x=read(),a[i].y=read();F(i,1,n) g[s][i]=g[i][s]=min(a[i].x-1,ny-a[i].y),g[i][t]=g[t][i]=min(a[i].y-1,nx-a[i].x);F(i,1,n) F(j,i,n) g[i][j]=g[j][i]=getdis(a[i],a[j])/2;ans=inf;F(i,1,n) ans=min(ans,getdis(a[i],(data){1,1})),ans=min(ans,getdis(a[i],(data){nx,ny}));g[s][t]=g[t][s]=min(nx-1,ny-1);spfa();ans=min(ans,dis[t]);printf("%.2lf\n",ans);
}
bzoj3007 拯救小云公主相关推荐
- bzoj3007: 拯救小云公主(二分+并查集)
挺水的题...好多题解说是对偶图,其实感觉不能算严格意义上的对偶图吧QAQ 先二分答案r,然后以boss为中心半径为r的圆不能走,求能否从左下走到右上. 不能从左下走到右上,说明这堆圆把图隔开了,于是 ...
- P2498 [SDOI2012]拯救小云公主
P2498 [SDOI2012]拯救小云公主 题意: 一个row * line的矩形,英雄在左下角(1,1),公主在右上角(row,line),有n个位置是boss.英雄现在要去公主那里,但是要避开b ...
- 二分+并查集【bzoj3007】[SDOI2012]拯救小云公主
Description 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意 ...
- bzoj 3007 拯救小云公主
http://www.elijahqi.win/archives/3705 Description 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门 ...
- [SDOI2012]拯救小云公主
题目 题目描述 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意识到自己 ...
- 洛谷P2498 [SDOI2012]拯救小云公主 【二分 + 并查集】
题目 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意识到自己还是等级1 ...
- BZOJ 3007: 拯救小云公主
Description 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意 ...
- bzoj3007 解救小云公主
3007: 解救小云公主 Time Limit: 5 Sec Memory Limit: 512 MB Submit: 159 Solved: 71 [Submit][Status][Discus ...
- 【BZOJ】3007 拯救小云公主 最短路径
题目传送门 题目大意:给定一个矩形和矩形内一些点,求一条左上角到右下角的路径,使所有点和矩形边界到这条路径的最小距离最大. 解法1:最小距离最大,想到二分,然后题目就转化成:矩形内有一些圆形障碍,问左 ...
最新文章
- oracle中 关于触发器,oracle 闪回关于触发器的bug
- JDK 13 的 12 个新特性,真心涨姿势了
- php做gui,php7 图形用户界面GUI如何开发
- [转] SQL的3种连接查询
- MySQL索引优化实战
- QAQorz的训练记录
- linux下安装编译网卡驱动
- Metalink使用指南
- 小米 pegasus_使用Google的Pegasus库生成摘要
- 启动子级时出错_WHO I级脑膜瘤手术或放射外科治疗后的恶性转变
- django学习笔记:AdminSite界面配置
- 夏令时 DST (Daylight Saving Time) java中的夏令时。
- html css important,css中的important是什么意思?
- baseurl php,html base URL是什么?html base详细解析汇总
- linux android交叉编译,【转】搭建arm-linux-gcc交叉编译工具链环境(Android原生(JNI)开发环境搭建)...
- 华为笔试题——分礼物
- 西门子cpu指示灯含义_CPU中的指示灯亮的意思
- 大数据发展的7个趋势 -- 阿里技术专家权威解读
- H5新增音频标签-audio
- c语言千位分隔符代码if函数,JavaScript实现千位分隔符
热门文章
- 耗时一周时间,我构建了基于知识图谱的医生推荐系统(附完整版 Python 源码)
- 学习Qss--背景属性
- 【HTTP】检测服务器是否支持断点续传
- 开发微信小程序商城(源代码+教程),新商云-全渠道互通
- 小狼豪输入发相关安装使用----值得推荐 的输入法
- 挪威大学计算机科学专业排名,挪威奥斯陆大学专业排名
- PyCrypto密码学库源码解析(二)RSA参数生成
- 概率导论(Introduction to Probability, 2E)学习笔记 Part Ⅰ
- 惠普HP LaserJet P4515xm 打印机驱动
- 快乐课堂V7.3发布 -- 精致唯美 至臻体验 简单实用