博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 3622 Bomb Game(2-sat)
阅读量:6171 次
发布时间:2019-06-21

本文共 2002 字,大约阅读时间需要 6 分钟。

HDU 3622 Bomb Game

题意:求一个最大半径,使得每一个二元组的点任选一个,能够得到全部圆两两不相交

思路:显然的二分半径,然后2-sat去判定就可以

代码:

#include 
#include
#include
#include
#include
#include
using namespace std;const int MAXNODE = 105;struct TwoSet { int n; vector
g[MAXNODE * 2]; bool mark[MAXNODE * 2]; int S[MAXNODE * 2], sn; void init(int tot) { n = tot * 2; for (int i = 0; i < n; i += 2) { g[i].clear(); g[i^1].clear(); } memset(mark, false, sizeof(mark)); } void add_Edge(int u, int uval, int v, int vval) { u = u * 2 + uval; v = v * 2 + vval; g[u^1].push_back(v); g[v^1].push_back(u); } void delete_Edge(int u, int uval, int v, int vval) { u = u * 2 + uval; v = v * 2 + vval; g[u^1].pop_back(); g[v^1].pop_back(); } bool dfs(int u) { if (mark[u^1]) return false; if (mark[u]) return true; mark[u] = true; S[sn++] = u; for (int i = 0; i < g[u].size(); i++) { int v = g[u][i]; if (!dfs(v)) return false; } return true; } bool solve() { for (int i = 0; i < n; i += 2) { if (!mark[i] && !mark[i + 1]) { sn = 0; if (!dfs(i)){ for (int j = 0; j < sn; j++) mark[S[j]] = false; sn = 0; if (!dfs(i + 1)) return false; } } } return true; }} gao;const int N = 105;int n;struct Point { double x, y; void read() { scanf("%lf%lf", &x, &y); }} p[N][2];inline double dis(Point a, Point b) { double dx = a.x - b.x; double dy = a.y - b.y; return sqrt(dx * dx + dy * dy);}inline bool xj(Point a, Point b, double r) { if (dis(a, b) > 2 * r) return false; return true;}bool judge(double r) { gao.init(n); for (int i = 0; i < n; i++) { for (int j = i + 1; j < n; j++) { for (int x = 0; x < 2; x++) { for (int y = 0; y < 2; y++) { if (xj(p[i][x], p[j][y], r)) gao.add_Edge(i, x, j , y); } } } } return gao.solve();}int main() { while (~scanf("%d", &n)) { for (int i = 0; i < n; i++) for (int j = 0; j < 2; j++) p[i][j].read(); double l = 0, r = 1e5; for (int i = 0; i < 30; i++) { double mid = (l + r) / 2; if (judge(mid)) l = mid; else r = mid; } printf("%.2lf\n", l); } return 0;}

转载地址:http://mttba.baihongyu.com/

你可能感兴趣的文章
基于DobboX的SOA服务集群搭建
查看>>
C#设计模式之装饰者
查看>>
[noip模拟20170921]模版题
查看>>
获取ip
查看>>
Spring Shell简单应用
查看>>
移动app可开发的意见于分析
查看>>
周总结7
查看>>
类似OutLook布局的开源控件XPanderControls
查看>>
Web前端工程师成长之路——知识汇总
查看>>
[2018-9-4T2]探索黑暗dark
查看>>
【学术信息】中科院2019年学术期刊分区-综合性期刊
查看>>
ShareObject离线存储相关
查看>>
C++ XML
查看>>
windows批处理 打开exe后关闭cmd
查看>>
Flask开发系列之快速入门
查看>>
关于SaveChanges
查看>>
php7扩展开发 一 获取参数
查看>>
处女座与复读机
查看>>
Laravel 5.2数据库--迁移migration
查看>>
ExtJs Extender controls 不错的例子
查看>>