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.当英雄意识到自己还是等 ...
随机推荐
- tomcat指向外部项目
参考 https://www.cnblogs.com/ysocean/p/6893446.html conf/server.xml中增加 <Context path="/myweb&q ...
- CSS垂直翻转/水平翻转提高web页面资源重用性
/*水平翻转*/ .flipx { -moz-transform:scaleX(-1); -webkit-transform:scaleX(-1); ...
- Linux下常用的编辑文件与保存命令
打开文件: vi aaa.conf 编辑: i 编辑结束,按ESC 键 跳到命令模式,然后输入退出命令: :w (write)保存文件但不退出vi 编辑 :w! 强制保存,不退出vi 编辑 :w fi ...
- 第九章 词典 (d2)散列:排解冲突(2)
- WAS 与IHS集成问题
1.安装好WAS与IHS后 发布Web发现无法启动 查阅资料后发现缺少插件Plugins 于是去下载安装对应版本的Plugins 发现还是有问题 后来想起发布web01时,插件还未安装.因此重新发布一 ...
- 牛客练习赛15A-吉姆的运算式(Python正则表达式瞎搞)
传送门 题意:出现的数字,取最后一个数字即可. Python正则表达式提取数字 代码: import re str = input() a = re.findall(r'\-*\d+(?:\.\d+) ...
- redis-storage介绍[转]
背景: 当时我们正在做一个游戏项目,游戏项目相比于web项目,更追求的是单机的性能,而我们对单个请求的处理时间有着bt级的需求(一个完整的api请求控制在10ms以内).当时我们的数据层用的是ttse ...
- Intellij Idea创建Android项目
创建工程前请已下载安装好了Intellij Idea和Android SDK. Intellij idea 2016.3.2 步骤 Android SDK设置 在FIle –> Other Se ...
- mvc下添加 EntityFramework的引用
首先 打开工具-扩展和更新-联机-Visual Studio库,找到NuGet Package Manager 检查是否 安装,如果没有安装 先安装插件 安装成功后,右键点击‘引用’,如下图 然后 ...
- SQL Server 触发器 表的特定字段(一个字段)更新时,触发Update触发器
CREATE TRIGGER [dbo].[Trg_Update_table1_column1] on table1 after update as if update (column1) ...