fzyzojP2119 -- 圆圈游戏


说白了,就是这个样子:

这个玩意明显是一个优美的树形结构
是个森林
然后建个虚点0,并且w[0]=0,然后树形dp即可
f[x]=max(w[x],∑f[son])
难点是:树怎么建?
就要上计算几何了:
如果我们用扫描线扫过去
发现,同时存在的两个圆,由于不相交,不相切,所以 相对位置始终保持不变
或者说,不论扫到哪个位置,两个圆的四个纵坐标的相对大小是固定的。

基于这个优秀的事实,
判断圆的相互包含关系,这样处理:


画个图就明白了
这个都是基于:“纵坐标相对大小不变”的事实,所以,不管扫描线怎么动,虽然纵坐标变了,但是不用重新建平衡树,因为形态还是不变的
这使得插入的时候,这个树还是正确的,直接找前驱就是对的了
用set就可以
重载小于号,用全局变量P来比较(只有插入和查询前驱的时候会进行比较)
(比较的第二关键字还是有用的,因为同时插入两个半圆壳,纵坐标那个时候是相同的)
由于会出现r=0的情况,所以扫描线的处理,横坐标相同,插入在前,删除在后。
代码:
#include<bits/stdc++.h>
#define reg register int
#define il inline
#define numb (ch^'0')
using namespace std;
typedef long long ll;
il void rd(ll &x){
char ch;x=;bool fl=false;
while(!isdigit(ch=getchar()))(ch=='-')&&(fl=true);
for(x=numb;isdigit(ch=getchar());x=x*+numb);
(fl==true)&&(x=-x);
}
namespace Miracle{
const int N=+;
int n;
ll P;//PPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPP
struct circle{
ll x,y,r;
int w;
long double calc(ll p,int fl){
return (long double)y+fl*sqrt((long double)r*r-(long double)(p-x)*(p-x));
}
}c[N];
struct po{
int id,fl;//fl=1 up; fl=-1 down
po(){}
po(int x,int y){
id=x;fl=y;
}
bool friend operator <(po a,po b){
if(c[a.id].calc(P,a.fl)!=c[b.id].calc(P,b.fl)) return c[a.id].calc(P,a.fl)<c[b.id].calc(P,b.fl);
return a.fl<b.fl;
}
};
set<po>s;
set<po>::iterator it;
struct que{
int pos,id,typ;
bool friend operator <(que a,que b){
if(a.pos!=b.pos)return a.pos<b.pos;
return a.typ>=b.typ;
}
}q[*N];
int tot;
struct node{
int nxt,to;
}e[*N];
int hd[N],cnt;
int du[N];
int fa[N];
void add(int x,int y){
e[++cnt].nxt=hd[x];
e[cnt].to=y;
hd[x]=cnt;
}
int f[N];
bool vis[N];
void dfs(int x){
vis[x]=;
for(reg i=hd[x];i;i=e[i].nxt){
int y=e[i].to;
if(!vis[y]){
dfs(y);
f[x]+=f[y];
}
}
f[x]=max(f[x],c[x].w);
}
int main(){
scanf("%d",&n);
for(reg i=;i<=n;++i){
rd(c[i].x);rd(c[i].y);rd(c[i].r);//rd(c[i].w);
scanf("%d",&c[i].w);
q[++tot].pos=c[i].x-c[i].r;
q[tot].id=i;q[tot].typ=; q[++tot].pos=c[i].x+c[i].r;
q[tot].id=i;q[tot].typ=-;
}
sort(q+,q+tot+);
for(reg i=;i<=tot;++i){
P=q[i].pos;
// cout<<q[i].pos<<" "<<q[i].id<<" "<<q[i].typ<<endl;
// cout<<c[1].calc(P,1)<<" and "<<c[1].calc(P,-1)<<" "<<c[q[i].id].calc(P,1)<<endl;
if(q[i].typ==){
it=s.upper_bound(po(q[i].id,));
if(it!=s.end()){
if((*it).fl==){
// cout<<" find up "<<endl;
fa[q[i].id]=(*it).id;
add((*it).id,q[i].id);
}else{
fa[q[i].id]=fa[(*it).id];
add(fa[(*it).id],q[i].id);
}
}else{
fa[q[i].id]=;
add(,q[i].id);
}
s.insert(po(q[i].id,));
s.insert(po(q[i].id,-));
}else{
s.erase(po(q[i].id,));
s.erase(po(q[i].id,-));
}
}
dfs();
printf("%d\n",f[]);
return ;
} }
signed main(){
freopen("2.in","r",stdin);
freopen("2.out","w",stdout);
Miracle::main();
return ;
} /*
Author: *Miracle*
Date: 2019/2/10 8:46:45
*/
fzyzojP2119 -- 圆圈游戏的更多相关文章
- 4.9 省选模拟赛 圆圈游戏 树形dp set优化建图
由于圆不存在相交的关系 所以包容关系形成了树的形态 其实是一个森林 不过加一个0点 就变成了树. 考虑对于每个圆都求出最近的包容它的点 即他的父亲.然后树形dp即可.暴力建图n^2. const in ...
- 剑指Offer-孩子们的游戏(圆圈中最后剩下的数)
package Other; import java.util.LinkedList; /** * 孩子们的游戏(圆圈中最后剩下的数) * 每年六一儿童节,牛客都会准备一些小礼物去看望孤儿院的小朋友, ...
- 剑指offer-孩子们的游戏(圆圈中最后剩下的数)-知识迁移能力-python
题目描述 每年六一儿童节,牛客都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此.HF作为牛客的资深元老,自然也准备了一些小游戏.其中,有个游戏是这样的:首先,让小朋友们围成一个大圈.然后,他随机指 ...
- html5+Canvas实现酷炫的小游戏
最近除了做业务,也在尝试学习h5和移动端,在这个过程中,学到了很多,利用h5和canvas做了一个爱心鱼的小游戏.点这里去玩一下 PS: 貌似有点闪屏,亲测多刷新两下就好了==.代码在本地跑都不会闪, ...
- tyvj1008 传球游戏
背景 NOIP2008复赛普及组第三题 描述 上体育课的时候,小蛮的老师经常带着同学们一起做游戏.这次,老师带着同学们一起做传球游戏. 游戏规则是这样的:n个同学站成一个圆圈,其中的一个同学手里拿着一 ...
- Android 之surfaceView (画动态圆圈)
通过之前介绍的如何自定义View, 我们知道使用它可以做一些简单的动画效果.它通过不断循环的执行View.onDraw方法,每次执行都对内部显示的图形做一些调整,我们假设 onDraw方法每秒执行 ...
- 经典DOS游戏皇帝攻略(曾经的回忆)
最完美攻略>>>>> -------------------------------------------------------------------------- ...
- OpenNI结合Unity3D Kinect进行体感游戏开发(转)
OpenNI结合Unity3D Kinect进行体感游戏开发(转) 楼主# 更多 发布于:2012-07-17 16:42 1. 下载安装Unity3D(目前版本为3.4)2. 下载OpenN ...
- 七、考反映小游戏《苹果iOS实例编程入门教程》
该app为应用的功能为一个简单的考反应游戏 纲要:-UIButton, UILabel, UIImageView 的运用:-利用rendom增加游戏可玩性: 游戏说明: 在按下开始游戏后,分为三盏的指 ...
随机推荐
- openstack系列文章(二)
学习openstack的系列文章-keystone openstack 架构 Keystone 基本概念 Keystone 工作流程 Keystone Troubleshooting 1. open ...
- 无法连接 Plugins Market 失效的日子
一.问题背景 不知道是什么原因,我的 Intellij 连接不上 Plugins Market,这时候我需要使用 @Data 注解来自动生成 Getter.Setter 方法.在添加了相应的依赖之后, ...
- Metasploit漏洞利用,三个入侵主机实战案例
受害者主机 windows2003 ie模拟工具ietest ie5.5/6/7/ 漏洞:MS10_002,MS10_018,MS12-020 ---------------------------- ...
- php在数组中判断某个值是否存在
php在数组中查找指定值是否存在的方法有很多,记得很久以前我一直都是傻傻的用foreach循环来查找的,下面我主要分享一下用php内置的三个数组函数来查找指定值是否存在于数组中,这三个数组分别是 in ...
- 2018年第九届蓝桥杯【C++省赛B组】
2标题:明码 汉字的字形存在于字库中,即便在今天,16点阵的字库也仍然使用广泛.16点阵的字库把每个汉字看成是16x16个像素信息.并把这些信息记录在字节中. 一个字节可以存储8位信息,用32个字节就 ...
- BugPhobia发布篇章:学霸在线系统正式发布
Alpha阶段的服务器部署和移植工作最终完成,http://10.2.26.67/,期待您的访问~ 首先,请允许bugphobia团队对您的访问给予感谢以及诚恳的致歉.受服务器端的硬件限制,目前学霸在 ...
- 小组冲刺第十一天站立会议(发布Alpha版+网站链接)
注: “助成”招聘网站链接:http://58.87.74.131:8080/zhucheng 欢迎大家进行评测. 一.任务看板: 二.燃尽图: 三.团队成员合照: 四.任务总结: 今天我们发布网站B ...
- 线程局部存储TLS(thread local storage)
同一全局变量或者静态变量每个线程访问的是同一变量,多个线程同时访存同一全局变量或者静态变量时会导致冲突,尤其是多个线程同时需要修改这一变量时,通过TLS机制,为每一个使用该全局变量的线程都提供一个变量 ...
- 团队GIT实战总结
项目要求 组长博客 遇到的困难及解决办法 组员1(组长):王彬 遇到的困难 在团队任务分工的时候没有充分照顾到所有人,导致队员们的工作量不均. 现场编程时间不够 解决办法 在此对组员们表示抱歉,由于 ...
- frist Django app — 一、 创建工程(转载)
转载地址:https://www.cnblogs.com/sunshine-2015/p/5658283.html 缘起 既然python都学了,学习python的时候感觉是相见恨晚,一种新的编程语言 ...