HDU 5299 圆扫描线 + 树上删边
几何+博弈的简单组合技
给出n个圆,有包含关系,以这个关系做游戏,每次操作可以选择把一个圆及它内部的圆全部删除,不能操作者输。
圆的包含关系显然可以看做是树型结构,所以也就是树上删边的游戏。
而找圆的包含关系,这题数据不大可用n^2复杂度找。也可以用扫描线,实时记录其节点父亲的情况。3种情况分类讨论一下就可以了。
/** @Date : 2017-10-18 20:21:54
* @FileName: HDU 5299 圆扫描线+树上删边.cpp
* @Platform: Windows
* @Author : Lweleth (SoungEarlf@gmail.com)
* @Link : https://github.com/
* @Version : $Id$
*/
#include <bits/stdc++.h>
#define LL long long
#define PII pair<int ,int>
#define MP(x, y) make_pair((x),(y))
#define fi first
#define se second
#define PB(x) push_back((x))
#define MMG(x) memset((x), -1,sizeof(x))
#define MMF(x) memset((x),0,sizeof(x))
#define MMI(x) memset((x), INF, sizeof(x))
using namespace std; const int INF = 0x3f3f3f3f;
const int N = 2e4+20;
const double eps = 1e-8; struct yuu
{
double x, y, r;
yuu(){}
yuu(double _x, double _y, double _r):x(_x), y(_y), r(_r){}
}; yuu pt[N];
double scanx;
struct Node{
int id, flag;
Node(){}
Node(int i, int f):id(i),flag(f){}
bool operator <(const Node &b) const {
double dis1 = sqrt(pt[id].r*pt[id].r - (scanx - pt[id].x) * (scanx - pt[id].x));
double dis2 = sqrt(pt[b.id].r*pt[b.id].r - (scanx - pt[b.id].x) * (scanx - pt[b.id].x));
double y1 = pt[id].y + flag * dis1;
double y2 = pt[b.id].y + b.flag * dis2;
return y1 < y2 || (fabs(y1 - y2) < eps && flag < b.flag);
}
}; pair<double, int>evt[2*N];
vector<int>edg[N];
set<Node>st;
int cnt[N];
int fa[N]; void init(int n)
{
for(int i = 0; i <= n; i++)
{
fa[i] = 0;
edg[i].clear();
}
st.clear();
}
int get_sg(int x, int pre)
{
int res = 0;
for(auto i : edg[x])
{
if(i == pre)
continue;
res ^= 1 + get_sg(i, x);
}
return res;
} int main()
{
int T;
cin >> T;
while(T--)
{
int n;
scanf("%d", &n);
init(n);
for(int i = 1; i <= n; i++)
{
double x, y, r;
scanf("%lf%lf%lf", &x, &y, &r);
pt[i] = yuu(x, y, r);
evt[(i-1)*2] = MP(x - r, i);
evt[(i-1)*2 + 1] = MP(x + r, i + n);
}
sort(evt, evt + 2 * n); for(int i = 0; i < n * 2; i++)
{
scanx = evt[i].fi;
int t = evt[i].se;
if(t <= n)
{
int up = -1;
int dw = -1;
st.insert(Node(evt[i].se, -1));
auto pos = st.lower_bound(Node(evt[i].se,-1));
if((++pos) != st.end())
up = pos->id;
if((--pos) != st.begin())
dw = (--pos)->id;
if(up == dw && ~up)
{
fa[evt[i].se] = up;
edg[up].PB(evt[i].se);
}
else if(~dw && ~up)
{
if(fa[up] == fa[dw])
{
fa[evt[i].se] = fa[up];
edg[fa[up]].PB(evt[i].se);
}
else if(fa[up] == dw)
{
fa[evt[i].se] = dw;
edg[dw].PB(evt[i].se);
}
else if(fa[dw] == up)
{
fa[evt[i].se] = up;
edg[up].PB(evt[i].se);
}
}
else edg[0].PB(evt[i].se);
st.insert(Node(evt[i].se, 1));
}
else
{
st.erase(Node(evt[i].se-n, 1));
st.erase(Node(evt[i].se-n,-1));
}
}
/*for(int i = 0; i <= n; i++,cout<<endl)
{
cout<<i<<":";
for(auto j:edg[i])
printf("%d ", j);
}*/
int sg = get_sg(0, -1);
printf("%s\n", sg?"Alice":"Bob");
}
return 0;
}
HDU 5299 圆扫描线 + 树上删边的更多相关文章
- HDU 5299 Circles Game
HDU 5299 思路: 圆扫描线+树上删边博弈 圆扫描线有以下四种情况,用set维护扫描线与圆的交点,重载小于号 代码: #pragma GCC optimize(2) #pragma GCC op ...
- HDU 3094 树上删边 NIM变形
基本的树上删边游戏 写过很多遍了 /** @Date : 2017-10-13 18:19:37 * @FileName: HDU 3094 树上删边 NIM变形.cpp * @Platform: W ...
- 【HDU 3590】 PP and QQ (博弈-Anti-SG游戏,SJ定理,树上删边游戏)
PP and QQ Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- POJ Christmas Game [树上删边游戏 Multi-SG]
传送门 题意: 有N 个局部联通的图.Harry 和Sally 轮流从图中删边,删去一条边后,不与根节点相连的部分将被移走.Sally 为先手.图是通过从基础树中加一些边得到的.所有形成的环保证不共用 ...
- POJ.3710.Christmas Game(博弈论 树上删边游戏 Multi-SG)
题目链接 \(Description\) 给定n棵"树",每棵"树"的节点可能"挂着"一个环,保证没有环相交,且与树只有一个公共点. 两人轮 ...
- POJ 3710 无向图简单环树上删边
结论题,这题关键在于如何转换环,可以用tarjan求出连通分量后再进行标记,也可以DFS直接找到环后把点的SG值变掉就行了 /** @Date : 2017-10-23 19:47:47 * @Fil ...
- 【BZOJ 2688】 2688: Green Hackenbush (概率DP+博弈-树上删边)
2688: Green Hackenbush Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 42 Solved: 16 Description ...
- HDU5299 圆的扫描线 && 树上删边博弈
HDU5299 圆的扫描线 && 树上删边博弈 标签(空格分隔): 未分类 给出若干个圆,可以互相嵌套但不相交或相切. 每次删去一个圆和它内部的圆,进行博弈,问谁赢. 分成两部分.首先 ...
- codeforces gym #101161F-Dictionary Game(字典树+树上删边游戏)
题目链接: http://codeforces.com/gym/101161/attachments 题意: 给一个可以变化的字典树 在字典树上删边 如果某条边和根节点不连通那么这条边也删除 谁没得删 ...
随机推荐
- effective c++ 笔记 (5-8)
//---------------------------15/03/26---------------------------- //#5 了解c++默默编写并调用哪些函数 { /* c++会 ...
- Sterling B2B Integrator与SAP交互 - 02 安装配置
系统组成: 1. 服务器OS及硬件: OS: Red Hat Enterprise Linux Server release 6.6 Hardware: Virtual Machine, x86_64 ...
- AndroidPN环境建立
AndroidPN环境 AndroidPN实现了从服务器到android移动平台的文本消息推送.这里先简单说一下androidPN的安装过程. 下载androidpn-client-0.5.0.zip ...
- Linux使用expect实现免手动密码输入,linux免密码登陆
使用expect实现自动登录的脚本,网上有很多,可是都没有一个明白的说明,初学者一般都是照抄.收藏.可是为什么要这么写却不知其然.本文用一个最短的例子说明脚本的原理. 脚本代码如下: ###### ...
- IT简历
对很多IT毕业生来说,写简历投简历是必不可少的.一个好的简历已是面试成功的一半. 简历的目的是为了引人注意,争取让HR主动联系你去面试,不可避免的在简历中掺杂着一些水分,但是能争取到面试机会,再与HR ...
- 初始化Weex项目遇到的问题记录
Weex 提供了一个命令行工具 weex-toolkit 来帮助开发者使用 Weex.它可以用来快速创建一个空项目.初始化 iOS 和 Android 开发环境.调试.安装插件等操作. 目前 weex ...
- LeetCode 606. Construct String from Binary Tree根据二叉树创建字符串 (C++)
题目: You need to construct a string consists of parenthesis and integers from a binary tree with the ...
- ThinkPHP框架知识(比较全的知识)
php框架 一.真实项目开发步骤: 多人同时开发项目,协作开发项目.分工合理.效率有提高(代码风格不一样.分工不好) 测试阶段 上线运行 对项目进行维护.修改.升级(单个人维护项目,十分困难,代码风格 ...
- 这个不是第一次作业----艰难的安装Android studio历程
之前只听说过eclipse,后来从室友处得知,还有一个安卓的开发工具叫做Android studio,上网百度后发现网友普遍说Android studio比eclipse快,没想太多,删E装A. 在装 ...
- dispatch_block_t
通常我写一个不带参数的块回调函数是这样写的 在 . h 头文件中 定义类型 typedef void (^leftBlockAction)(); 在定义一个回调函数 -(void)leftButton ...