HDU 3622 Bomb Game
Description
\(n\) 个炸弹,每个炸弹有两个放置点,可以任选一个,问你最大的半径是多少.
Sol
二分+2-SAT+Tarjan.
首先二分一下答案.然后就成了一个2-SAT问题.
建模就是, \(i\) 如果和 \(j\) 的距离超过 \(x*2\),那么 \(i\) 只能选择 \(j\) ^ \(1\) 连边,同时 \(j\) 只能选择 \(i\) ^ \(1\) 连边.
最后用Tarjan所以下环,如果两个点在一个环中,那么就不合法.
Code
#include <bits/stdc++.h>
using namespace std; #define F first
#define S second
#define mpr make_pair
#define sqr(x) ((x)*(x))
const int N = 205;
const double eps = 1e-5;
typedef pair< int,int > pr;
typedef pair< pr,pr > prr; int n,c,cnt,cntb;
pr a[N];
vector< int > g[N];
int d[N],b[N];
int stk[N],instk[N],top; inline int in(int x=0) { scanf("%d",&x);return x; }
void clr() {
cntb=cnt=top=0;
for(int i=0;i<N;i++) g[i].clear();
memset(d,0,sizeof(d)),memset(b,0,sizeof(b)),memset(instk,0,sizeof(instk));
}
double Dist(pr x,pr y) { return sqrt((double)sqr(x.F-y.F)+sqr(x.S-y.S)); }
void Tarjan(int u,int fa) {
d[u]=++cnt,stk[++top]=u,instk[u]=1;int dfsn=cnt;
for(int i=0,v;i<(int)g[u].size();i++) if((v=g[u][i])!=fa) {
if(!d[v]) Tarjan(v,u);
if(instk[v]) d[u]=min(d[u],d[v]);
}
if(d[u]==dfsn) {
for(++cntb;stk[top]!=u;top--) {
b[stk[top]]=cntb,instk[stk[top]]=0;
}b[stk[top]]=cntb,instk[stk[top--]]=0;
}
// cout<<u<<":"<<d[u]<<" "<<dfsn<<endl;
}
int check(double x) {
clr();
for(int i=0;i<c;i++) for(int j=i&1 ? i+1 : i+2;j<c;j++)
if(Dist(a[i],a[j])<x*2) g[i].push_back(j^1),g[j].push_back(i^1);
// cout<<"("<<i<<","<<j<<")"<<Dist(a[i],a[j])<<endl,
for(int i=0;i<c;i++) if(!d[i]) Tarjan(i,i); /* cout<<x<<endl;
for(int i=0;i<c;i++) {
cout<<i<<":"<<endl;
for(int j=0;j<(int)g[i].size();j++) cout<<g[i][j]<<" ";
cout<<endl;
}
for(int i=0;i<c;i++) cout<<b[i]<<" ";cout<<endl;
cout<<"-------------------------"<<endl;*/ for(int i=0;i<c;i++) if(b[i]==b[i^1]) return 0;
return 1;
}
int main() {
// freopen("in.in","r",stdin);
while(~scanf("%d",&n)) {
c=0;
for(int i=1;i<=n;i++) {
int x=in(),y=in();
a[c++]=mpr(x,y);
x=in(),y=in();
a[c++]=mpr(x,y);
}
double l=0.0,r=20000.0,mid;
while(r-l > eps) {
mid=(l+r)/2.0;
if(check(mid)) l=mid;
else r=mid;
}printf("%.2lf\n",mid);
}return 0;
}
HDU 3622 Bomb Game的更多相关文章
- HDU 3622 Bomb Game(2-sat)
HDU 3622 Bomb Game 题目链接 题意:求一个最大半径,使得每一个二元组的点任选一个,能够得到全部圆两两不相交 思路:显然的二分半径,然后2-sat去判定就可以 代码: #include ...
- HDU 3622 Bomb Game(二分+2-SAT)
Bomb Game Time Limit: 10000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- hdu 3622 Bomb Game(二分+2-SAT)
Bomb Game Time Limit: 10000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- HDU 3622 Bomb Game(2-sat)
Bomb Game Time Limit: 10000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU 3622 Bomb Game(二分+2SAT)
题意:有一个游戏,有n个回合,每回合可以在指定的2个区域之一放炸弹,炸弹范围是一个圈,要求每回合的炸弹范围没有重合.得分是炸弹半径最小的值.求可以得到的最大分数. 思路:二分+2SAT. 二分炸弹范围 ...
- hdu 3622 Bomb Game【二分+2-SAT+tarjan】
用read()会挂 二分半径,显然最优的是所有原都用这个最小半径,然后2-SAT把相交的圆建图,跑tarjan判一下可行性即可 #include<iostream> #include< ...
- HDU - 3622 Bomb Game(二分+2-SAT)
题目大意:玩一个放炸弹游戏,有N次放炸弹的机会,每次放炸弹时,你都有两个位置能够选择.问怎样放炸弹,能使爆炸的炸弹的半径的最小值最大(炸弹爆炸半径能够控制,可是爆炸形成的圈不能有重叠部分) 解题思路: ...
- HDU 5934 Bomb(炸弹)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- 数位DP入门之hdu 3555 Bomb
hdu 3555 Bomb 题意: 在1~N(1<=N<=2^63-1)范围内找出含有 ‘49’的数的个数: 与hdu 2089 不要62的区别:2089是找不不含 '4'和 '62'的区 ...
随机推荐
- 嵌入式Linux驱动学习之路(十六)输入子系统
以前写的一些输入设备的驱动都是采用字符设备处理的.问题由此而来,Linux开源社区的大神们看到了这大量输入设备如此分散不堪,有木有可以实现一种机制,可以对分散的.不同类别的输入设备进行统一的驱动,所以 ...
- Oracle 中的伪列
昨天做了一个Oracle PL/SQL 相关的测试,其中有一道这样的题目: 下列那些是Oracle的伪列(ACD) A.ROWID B.ROW_NUMBER() C.LEVEL D.RO ...
- Lrc2srt精灵,增加自定义输出编码
2015.4.8 对中文支持有点问题,修改了一下,支持自定义输出编码! 修改了建议行末偏移,通常100到200最好了,人的反应时间! http://files.cnblogs.com/files/ro ...
- java多线程系类:JUC线程池:03之线程池原理(二)(转)
概要 在前面一章"Java多线程系列--"JUC线程池"02之 线程池原理(一)"中介绍了线程池的数据结构,本章会通过分析线程池的源码,对线程池进行说明.内容包 ...
- C#.NET 大型企业信息化系统集成快速开发平台 4.2 版本 - 多软件系统集成缓存体系改进
由于我们同时开发多个大型应用系统同时系统有大量用户.高并发用户,平时访问系统的用户数量就有3万多人在线.需要对几十个系统进行持续优化改进,同时要增强信息系统的各种安全性. 如此多的系统.如此多的用户, ...
- 千万别把WIFI玩坏了!关于WIFI的新鲜玩法和商业模式探讨
使用WIFI作为无线上网接入,也许大家都比较习以为常的.但是你们知道吗,其实WIFI还有很多种玩法:基于WIFI的身份识别,WIFI感知,WIFI Direct等等.今天我们会着重介绍一种WIFI的有 ...
- 从头写个http client(java)
不熟悉java,但我熟悉http,然后从头打造个简单的httpclient,支持get/post,支持gzip,支持重定向,支持encoding,支持transfer-encoding,支持ssl,支 ...
- Deepin 15.3 编译同步SudaMod 2.0
1.设置hosts,方便访问国外站点 $ wget https://raw.githubusercontent.com/racaljk/hosts/master/hosts -qO /tmp/host ...
- JavaScript数组的方法
push() :将参数加载到数组的最后,返回数组的长度 pop() :删除数组的最后一个元素,返回删除的值 shift() :删除数组的第一个元素,返回删除的值 unshift ...
- Spring AOP动态切换数据源
现在稍微复杂一点的项目,一个数据库也可能搞不定,可能还涉及分布式事务什么的,不过由于现在我只是做一个接口集成的项目,所以分布式就先不用了,用Spring AOP来达到切换数据源,查询不同的数据库就可以 ...