您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息
三六零分类信息网 > 嘉峪关分类信息网,免费分类信息发布

HDU 3622 Bomb Game(2

2024/3/1 6:40:52发布17次查看
hdu 3622 bomb game(2-sat二分) http://acm.hdu.edu.cn/showproblem.php?pid=3622 题意: 有n对地点,每对地点中的一个地方要放一个*,你可以控制*的爆炸半径,现在要求所有n个被放的*爆炸范围不重叠.问你在所有可行方案中的*爆炸最大半径是多少?(假
hdu 3622 bomb game(2-sat+二分)
http://acm.hdu.edu.cn/showproblem.php?pid=3622
题意:
        有n对地点,每对地点中的一个地方要放一个*,你可以控制*的爆炸半径,现在要求所有n个被放的*爆炸范围不重叠.问你在所有可行方案中的*爆炸最大半径是多少?(假设所有*爆炸半径相同,本假设与原提议的要求等价,可以自己想想)
分析:
        直接二分可能的爆炸半径mid,然后对于mid来说,遍历任意两点的所有组合.如果a=0的点与b=1的点的距离
ac代码:
#include#include#include#includeusing namespace std;const int maxn=100+10;int n;struct twosat{ int n; vector g[maxn*2]; int s[maxn*2],c; bool mark[maxn*2]; bool dfs(int x) { if(mark[x^1]) return false; if(mark[x]) return true; mark[x]=true; s[c++]=x; for(int i=0;in=n; for(int i=0;i0) mark[s[--c]]=false; if(!dfs(i+1)) return false; } } return true; }}ts;struct point{ double x,y;};struct node{ point p[2];}s[maxn];double dist(int i,int vi,int j,int vj){ double x1,y1,x2,y2; x1 = s[i].p[vi].x; y1 = s[i].p[vi].y; x2 = s[j].p[vj].x; y2 = s[j].p[vj].y; return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));}bool ok(double mid){ ts.init(n); for(int i=0;i
嘉峪关分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录