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.当英雄意识到自己还是等 ...
随机推荐
- canvas刮奖
(function (global, factory) { typeof module === 'object' && typeof module.exports === 'objec ...
- vue 学习笔记1
1.子组件在父组件的原生的事件例如一个child子组件的点击事件<child @click="handleClick">点击</child>这种情况在父组件 ...
- Numeric Type Attributes
[Numeric Type Attributes] INT(4) specifies an INT with a display width of four digits. This optiona ...
- sql语句where条件判断是否是相同的string时 原来不判断大小写
SELECT * from api_check where api ="Worker" SELECT * from api_check where api ="worke ...
- tomcat 启动报错org.hibernate.cfg.annotations.SimpleValueBinder.setType
url: https://blog.csdn.net/zhx_0323/article/details/78844323 # A fatal error has been detected by th ...
- Java 中位移运算符 >>,>>>,<<
Java 中的三种位移运算符 java中有三种移位运算符 << : 左移运算符,num << 1,相当于num乘以2 >> : ...
- appium +ios 判断元素是否存在,排除visible=“false”的数据
问题 想要判断name=xxx的元素是否存在,存在的话进行点击,结果页面并没有展示我要的元素时也提示找到了元素 原因 ios通过driver.find_element_by_name(“name值 ...
- 【scrapy】爬虫中报Forbidden by robots.txt
需要在setting.py里找到ROBOTSTXT_OBEY并设为false 来源:https://blog.csdn.net/yimingsilence/article/details/521197 ...
- PHP从规定字符中生成固定位数随即串
}
- mysql windows安装资源
压缩包资源 https://mirrors.tuna.tsinghua.edu.cn/mysql/downloads/MySQL-5.7/ 配置流程 https://blog.csdn.net/hel ...