[SDOI2012]拯救小云公主
题解:
是一个不错的题目
首先我们可以考虑二分答案
然后变成判定性问题
对于每个画一个圆 当其会被阻断时就是答案
阻断有四种情况 左下 上下 左右 右上
但是这样是n^2a(n)*logn的
考虑直接spfa 那是kn^2的
但是洛谷的空间是128的。。有点小
代码:
// luogu-judger-enable-o2
#include <bits/stdc++.h>
using namespace std;
#define N 10000000
#define INF 1e9
double x[],y[],dis[];
int head[];
int n,a,b,l;
bool inq[];
struct re{
int a,b;
double c;
}e[N];
void arr(int x,int y,double z)
{
e[++l].a=head[x];
e[l].b=y;
e[l].c=z;
head[x]=l;
}
queue<int>q;
int cnt=,cnt2;
void spfa()
{
while (!q.empty())
{
cnt++;
int xx=q.front(); q.pop();
int u=head[xx];
while (u)
{
cnt2++;
int v=e[u].b;
if (max(dis[xx],e[u].c)<dis[v])
{
dis[v]=max(dis[xx],e[u].c);
if (!inq[v])
{
inq[v]=; q.push(v);
}
}
u=e[u].a;
}
inq[xx]=;
}
}
int main()
{
//std::ios::sync_with_stdio(false);
cin>>n>>a>>b;
for (int i=;i<=n;i++) cin>>x[i]>>y[i];
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
{
double s=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
s/=;
arr(i,j,s);
}
int s1=n+,s2=n+,s3=n+,s4=n+;
for (int i=;i<=n;i++)
{
arr(s1,i,x[i]-); arr(i,s1,x[i]-);
arr(s2,i,b-y[i]); arr(i,s2,b-y[i]);
arr(s3,i,y[i]-); arr(i,s3,y[i]-);
arr(s4,i,a-x[i]); arr(i,s4,a-x[i]);
}
double ans=INF;
for (int i=;i<=s4;i++) dis[i]=INF;
dis[s1]=; dis[s2]=;q.push(s1); q.push(s2);
spfa();
ans=min(ans,dis[s3]); ans=min(ans,dis[s4]);
ans=min(ans,dis[s4]); ans=min(ans,dis[s3]);
printf("%.2f",ans);
return ;
}
[SDOI2012]拯救小云公主的更多相关文章
- 洛谷 P2498 [SDOI2012]拯救小云公主 解题报告
P2498 [SDOI2012]拯救小云公主 题目描述 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到\(boss\)的洞穴门口,他一下子就懵了,因为面前不只是一 ...
- 二分+并查集【bzoj3007】[SDOI2012]拯救小云公主
Description 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意 ...
- P2498 [SDOI2012]拯救小云公主
\(\color{#0066ff}{ 题目描述 }\) 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只bos ...
- 洛谷P2498 [SDOI2012]拯救小云公主 【二分 + 并查集】
题目 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意识到自己还是等级1 ...
- BZOJ 3007 [SDOI2012]拯救小云公主 - 对偶图 + 并查集
Solution 答案具有单调性, 显然可以二分答案. 有两个注意点 : 英雄是可以随便走的, 也就是不是网格图... 还有坐标不能小于$1$ QAQ 开始时英雄在左下角, 公主在右上角, 我们反过来 ...
- 【BZOJ】【3007】拯救小云公主
思路题 我的naive的做法是二分答案+判定是否有路径可走……但是没有正确理解[走的方向任意]这句话…… 其实就是说想咋走咋走= =360°无死角乱走…… 所以其实是个平面上的问题…… 我们可以换个方 ...
- BZOJ:4219: 跑得比谁都快 3007: 拯救小云公主
4219: 跑得比谁都快 3007: 拯救小云公主 三角剖分的解释可以看这里:http://www.cnblogs.com/Enceladus/p/6706444.html 后一道是前一道的弱化版. ...
- 【BZOJ3007】拯救小云公主 二分+几何+对偶图
[BZOJ3007]拯救小云公主 Description 英雄又即将踏上拯救公主的道路…… 这次的拯救目标是——爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了 ...
- bzoj3007: 拯救小云公主
Description 英雄又即将踏上拯救公主的道路…… 这次的拯救目标是——爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是 ...
随机推荐
- xml总结(一 )
一.了解 XML(eXtensive Markup Language)可扩展标记语言. XML是被用来传输和存储数据,焦点是内容,是对html的补充. HTML是将数据进行格式化显示.xml需要自定义 ...
- string和list互转
import string str = 'abcde' list = list(str) OR list = str.split() list ['a', 'b', 'c', 'd', 'e'] st ...
- Android Retrofit2.1.0设置编码格式GBK
设置接口如下: public interface IHttpService { /** * 获取userId * @param params * @return */ @FormUrlEncoded ...
- 二、主目录 Makefile 分析(3)
2.8 编译选项 重新回到 主 makefile 中执行 2.8.1 u-boot 的编译顺序 代码166 到 189 行,这些是 u-boot 文件编译的顺序,由代码可以看到,首先是从cpu/$( ...
- Mac下压力测试工具siege
安装: brew install siege 用法: siege -c 并发数 -t 运行测试时间 URL 如: siege -c 1000 -t 5S URL 这里要注意的是-t后面的时间要带单位, ...
- JavaScript客户端签名直传OSS
参考链接: https://help.aliyun.com/document_detail/31925.html?spm=5176.11065259.1996646101.searchclickres ...
- Android Handler面试解析
- Django开发笔记三
Django开发笔记一 Django开发笔记二 Django开发笔记三 Django开发笔记四 Django开发笔记五 Django开发笔记六 1.基于类的方式重写登录:views.py: from ...
- 教你如何使用android studio发布release 版本【转】
原文链接 想必还有人对如何在Android studio (以下简称as)发布release版本的app而狂刷百度吧?都是过来人,我很理解这种心情,百度到的基本是半成品,为什么这么说呢?百度一下,你就 ...
- Docker镜像原理
⒈是什么? 镜像是一种轻量级.可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码.运行时.库.环境变量以及配置文件等. 引用 UnionFs( ...