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 题意: 给一个可以变化的字典树 在字典树上删边 如果某条边和根节点不连通那么这条边也删除 谁没得删 ...
随机推荐
- identityServer4 中的概念(Scope,claim)
在IdentityServer中好多地方出现这几个词,这单词的解释也有好多大神解释过: chaim: ASP.NET Core 之 Identity 入门(一),这个是asp.net identity ...
- Js_图片轮换
本文介绍用javascript制作图片轮换效果,原理很简单,就是设置延时执行一个切换函数,函数里面是先设置下面的缩略图列表的白框样式,再设置上面大图的src属性,在IE中显示很正常,可是在FF中会有变 ...
- 前端菜鸟起飞之学会ps切图
由于之前只顾着追求效率,没有学习过PS,但其实这是前端开发人员需要学会的技能之一,曾经看过一个大佬的前端经验分享说他在招聘时遇到不会切图的会直接pass掉,可见前端开发人员学会切图是多么重要.通过观看 ...
- 吴恩达《AI For Everyone》_练习英语翻译_待更新
AI For Everyone https://www.coursera.org/learn/ai-for-everyone 讲师: Andrew Ng (吴恩达) CEO/Founder Landi ...
- PAT甲题题解-1117. Eddington Number(25)-(大么个大水题~)
如题,大水题...贴个代码完事,就这么任性~~ #include <iostream> #include <cstdio> #include <algorithm> ...
- 第二个Sprint ------第四、五、六、七天
27号.28号.29号有事回家,没能及时更新博客. 罗伟业:加减算术----乘除算式 返回一个完整正确(加减.乘除)的算式<考虑到低年级还没有完全掌握四则混合运算> 康取:四则混合运算 ...
- Manjaro Linux 没有声音
在Multimedia中的PulseAudio Volume Control中的设置可以解决
- mysql 列转行处理
CREATE TABLE `table1` ( `id` ) DEFAULT NULL, `name` ) CHARACTER SET utf8 DEFAULT NULL ) ENGINE=MyISA ...
- php面试问答
结合实际PHP面试,汇总自己遇到的问题,以及网上其他人遇到的问题,尝试提供简洁准确的答案 包含MySQL.Redis.Web.安全.网络协议.PHP.服务器.业务设计.线上故障.个人简历.自我介绍.离 ...
- Laravel 从入门到精通系列教程
转载;https://laravelacademy.org/laravel-tutorial-5_7 适用于 Laravel 5.5.5.6.5.7 版本,本系列教程将围绕一个 LTS 版本,然后采取 ...