BZOJ 3007 [SDOI2012]拯救小云公主 - 对偶图 + 并查集
Solution
答案具有单调性, 显然可以二分答案。
有两个注意点 : 英雄是可以随便走的, 也就是不是网格图。。。 还有坐标不能小于$1$ QAQ
开始时英雄在左下角, 公主在右上角, 我们反过来考虑, 让英雄不能到达公主那。
把每个boss 看作是以其坐标为圆心, $mid$为半径的圆。
这时必须满足条件 : 矩形的下边和 左边或上边能通过圆连接
或者 矩形的 右边 和 左边或上边能通过圆连接。
这样我们只需把 下边和右边看作一个点, 左边和上边看作一个点 , 用并查集合并能够通过圆连接的boss 和 边界。
最后判断两个边界是否在同一集合内即可。
Code
#include<cstdio>
#include<cstring>
#include<cmath>
#define R register
#define rd read()
using namespace std; const int N = 3e3 + ;
const double eps = 1e-;
const double EPS = 1e-; int n, row, line;
int S, T;
int f[N];
double Dis[N][N]; struct node {
int x, y;
}pos[N]; inline int read() {
int X = , p = ; char c = getchar();
for(;c > '' || c < ''; c = getchar()) if(c == '-') p = -;
for(; c >= '' && c <= ''; c = getchar()) X = X * + c - '';
return X * p;
} int get(int x) {
return f[x] == x ? x : f[x] = get(f[x]);
} inline void merge(int x, int y) {
x = get(x); y = get(y);
f[x] = y;
} inline double cal(int i, int j) {
double x = pos[i].x - pos[j].x;
double y = pos[i].y - pos[j].y;
return sqrt(x * x + y * y);
} bool jud(double dis) {
for(R int i = ; i <= n + ; ++i)
f[i] = i;
for(R int i = ; i <= n; ++i)
if(pos[i].x + dis + EPS >= row || pos[i].y - dis - EPS <= )
merge(, i);
for(R int i = ; i <= n; ++i)
if(pos[i].x - dis - EPS <= || pos[i].y + dis + EPS >= line)
merge(i, n + );
for(R int i = ; i <= n; ++i)
for(R int j = i + ; j <= n; ++j) {
int x = get(i), y = get(j);
if(x == y) continue;
if(Dis[i][j] <= * dis)
merge(i, j);
}
return get() != get(n + );
} int main()
{
n = rd; row = rd; line = rd;
S = , T = n + ;
for(R int i = ; i <= n; ++i) pos[i].x = rd, pos[i].y = rd;
for(R int i = ; i <= n; ++i)
for(R int j = i + ; j <= n; ++j)
Dis[i][j] = cal(i, j);
double l = , r = row;
int cnt = ;
if(line > row) r = line;
while(l + eps < r && cnt--) {
R double mid = (l + r) / ;
if(jud(mid)) l = mid;
else r = mid;
}
printf("%.2lf\n", l);
}
BZOJ 3007 [SDOI2012]拯救小云公主 - 对偶图 + 并查集的更多相关文章
- 洛谷 P2498 [SDOI2012]拯救小云公主 解题报告
P2498 [SDOI2012]拯救小云公主 题目描述 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到\(boss\)的洞穴门口,他一下子就懵了,因为面前不只是一 ...
- 【BZOJ】【3007】拯救小云公主
思路题 我的naive的做法是二分答案+判定是否有路径可走……但是没有正确理解[走的方向任意]这句话…… 其实就是说想咋走咋走= =360°无死角乱走…… 所以其实是个平面上的问题…… 我们可以换个方 ...
- 二分+并查集【bzoj3007】[SDOI2012]拯救小云公主
Description 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意 ...
- P2498 [SDOI2012]拯救小云公主
\(\color{#0066ff}{ 题目描述 }\) 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只bos ...
- 洛谷P2498 [SDOI2012]拯救小云公主 【二分 + 并查集】
题目 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意识到自己还是等级1 ...
- [SDOI2012]拯救小云公主
题解: 是一个不错的题目 首先我们可以考虑二分答案 然后变成判定性问题 对于每个画一个圆 当其会被阻断时就是答案 阻断有四种情况 左下 上下 左右 右上 但是这样是n^2a(n)*logn的 考虑直接 ...
- BZOJ:4219: 跑得比谁都快 3007: 拯救小云公主
4219: 跑得比谁都快 3007: 拯救小云公主 三角剖分的解释可以看这里:http://www.cnblogs.com/Enceladus/p/6706444.html 后一道是前一道的弱化版. ...
- 【BZOJ3007】拯救小云公主 二分+几何+对偶图
[BZOJ3007]拯救小云公主 Description 英雄又即将踏上拯救公主的道路…… 这次的拯救目标是——爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了 ...
- 【bzoj3007】拯救小云公主 二分+对偶图+并查集
题目描述 英雄又即将踏上拯救公主的道路…… 这次的拯救目标是——爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意识到自己还是等 ...
随机推荐
- 终止执行js的方法
(一)在function里面 (1)return;(2)return false; (二)非function方法里面 alert("before error.");throw Sy ...
- CentOS6.5安装MySQL5.7详细教程(本人6.3也行)
本文参考http://www.cnblogs.com/lzj0218/p/5724446.html 主要参考博文: https://segmentfault.com/a/119000000304949 ...
- Gradle 在Eclipse中的使用
eclipse上gradle插件的安装 1)在Eclipse中选择Help -> Eclipse Marketplace…,输入buildship点击Go,然后选择Install安装Gradle ...
- jackson支持LocalDate等java8时间
pom文件增加依赖: <dependency> <groupId>com.fasterxml.jackson.datatype</groupId> <arti ...
- js保留小数点后面几位的方法
原文地址: http://www.jb51.net/article/45884.htm 四舍五入以下处理结果会四舍五入: ? 1 2 var num =2.446242342; num = num.t ...
- 在Plesk安装PHP的Memcached扩展
默认情况下,Plesk的PHP没有Memcached扩展,需要自己安装. Plesk-without-memcached,在Plesk下安装PHP Memcached扩展 PHP Memcache是 ...
- cnpm安装
npm install -g cnpm --registry=https://registry.npm.taobao.org 如果安装失败,可以使用 npm cache clean 清理缓存,然后再重 ...
- Apache+PHP+MySQL环境搭建
准备安装包:Apache: apache_2.2.11-win32.msi (http://pan.baidu.com/s/1nvdiNcH)PHP: php-5.2.5-Win32.zip (htt ...
- HDU 6315 Naive Operations(线段树区间整除区间)
Problem DescriptionIn a galaxy far, far away, there are two integer sequence a and b of length n.b i ...
- PTA 7-8 哈利·波特的考试(floyd)
哈利·波特要考试了,他需要你的帮助.这门课学的是用魔咒将一种动物变成另一种动物的本事.例如将猫变成老鼠的魔咒是haha,将老鼠变成鱼的魔咒是hehe等等.反方向变化的魔咒就是简单地将原来的魔咒倒过来念 ...