2019.02.21 bzoj1249: SGU277 HERO 动态凸包(set+凸包)
传送门
题意:动态插入点,维护凸包面积。
思路:用setsetset维护极角序来支持面积查询即可。
然后注意选原点的时候要从初始三个点随机平均系数来避免精度误差。
代码:
#include<bits/stdc++.h>
#define ri register ll
using namespace std;
typedef long long ll;
inline ll read(){
ll ans=0;
bool f=1;
char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f^=1;ch=getchar();}
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return f?ans:-ans;
}
struct pot{
ll x,y;
double ang;
pot(ll _x=0,ll _y=0):x(_x),y(_y){}
pot(ll _x,ll _y,double _ang):x(_x),y(_y),ang(_ang){}
friend inline pot operator+(const pot&a,const pot&b){return pot(a.x+b.x,a.y+b.y);}
friend inline pot operator-(const pot&a,const pot&b){return pot(a.x-b.x,a.y-b.y);}
friend inline ll operator^(const pot&a,const pot&b){return (ll)a.x*b.y-(ll)a.y*b.x;}
friend inline bool operator<(const pot&a,const pot&b){return a.ang<b.ang;}
}a[5];
set<pot>S;
typedef set<pot>::iterator It;
ll n;
ll ans=0;
inline ll Area(const pot&a,const pot&b,const pot&c){return (a-c)^(b-c);}
inline ll labs(const ll&x){return x>0?x:-x;}
inline pot Pre(const pot&now){
if(S.count(now)>0)return now;
It it=S.lower_bound(now);
if(it==S.begin())it=S.end();
return *(--it);
}
inline pot Suf(const pot&now){
It it=S.upper_bound(now);
if(it==S.end())it=S.begin();
return *it;
}
inline bool check(const pot&x){return Area(x,Suf(x),Pre(x))<=0;}
inline void insert(const pot&x){
if(check(x))return;
ans+=labs(Area(x,Suf(x),Pre(x)));
while(1){
pot p1=Pre(x),p2;
S.erase(p1);
p2=Pre(x);
if(Area(x,p2,p1)>=0){S.insert(p1);break;}
ans+=labs(Area(x,p2,p1));
}
while(1){
pot p1=Suf(x),p2;
S.erase(p1);
p2=Suf(x);
if(Area(x,p2,p1)<=0){S.insert(p1);break;}
ans+=labs(Area(p1,p2,x));
}
S.insert(x);
}
signed main(){
srand(time(NULL));
ll xxx=rand(),yyy=rand(),zzz=rand(),ttt=xxx+yyy+zzz;
double X,Y;
a[1].x=read(),a[1].y=read();
a[2].x=read(),a[2].y=read();
a[3].x=read(),a[3].y=read();
X=(double)((ll)a[1].x*xxx+(ll)a[2].x*yyy+(ll)a[3].x*zzz)/ttt;
Y=(double)((ll)a[1].y*xxx+(ll)a[2].y*yyy+(ll)a[3].y*zzz)/ttt;
for(ri i=1;i<=3;++i)S.insert(pot(a[i].x,a[i].y,atan2(a[i].y-Y,a[i].x-X)));
ans=labs(Area(a[1],a[2],a[3]));
for(ri x,y,tt=read();tt;--tt){
x=read(),y=read();
insert(pot(x,y,atan2(y-Y,x-X)));
cout<<ans<<'\n';
}
return 0;
}
2019.02.21 bzoj1249: SGU277 HERO 动态凸包(set+凸包)的更多相关文章
- bzoj1249: SGU277 HERO 动态凸包
动态维护凸包面积. //Achen #include<bits/stdc++.h> #define For(i,a,b) for(int i=(a);i<=(b);i++) #def ...
- 2019.02.21 bzoj2300: [HAOI2011]防线修建(set+凸包)
传送门 题意:动态维护凸包周长. 思路: 见这篇求面积的吧反正都是一个套路. 代码: #include<bits/stdc++.h> #define int long long #defi ...
- 2019.02.21 bzoj5317: [Jsoi2018]部落战争(凸包+Minkowski和)
传送门 题意:qqq次询问把一个凸包整体加一个向量(x,y)(x,y)(x,y)之后是否与另外一个凸包相交. 思路:转化一下发现只要会求A+B={v⃗=a⃗+b⃗∣a⃗∈A,b⃗∈B}A+B=\{\v ...
- 2019.02.21 bzoj2829: 信用卡凸包(凸包)
传送门 题意:给nnn个A∗BA*BA∗B的矩形,其中每个矩形的四个角被改造成了半径为rrr的四分之一 圆,问这些矩形的凸包周长. 思路:考虑求出圆心的凸包周长然后加上一个整圆的周长,证明很简单,略掉 ...
- 2019.02.26 bzoj4311: 向量(线段树分治+凸包)
传送门 题意: 支持插入一个向量,删去某一个现有的向量,查询现有的所有向量与给出的一个向量的点积的最大值. 思路: 考虑线段树分治. 先对于每个向量处理出其有效时间放到线段树上面,然后考虑查询:对于两 ...
- 2019.02.21 bzo1038: [ZJOI2008]瞭望塔(半平面交)
传送门 题意:给出一个nnn个点的轮廓,要求找一个高度最小的点使得它能够看见所有拐点. 思路:之间建半平面交然后取半平面交上的每个交点和每个轮廓更新答案即可. 代码: #include<bits ...
- 2019.02.21 bzoj2739: 最远点(决策单调性+分治)
传送门 题意简述:给一个N个点的凸多边形,求离每一个点最远的点. 思路:先根据初中数学知识证明决策是满足单调性的,然后上分治优化即可. 才不是因为博主懒得写二分+栈优化呢 代码: #include&l ...
- FFMpeg ver 20160219-git-98a0053 滤镜中英文对照 2016.02.21 by 1CM
FFMpeg ver 20160219-git-98a0053 滤镜中英文对照 2016.02.21 by 1CM T.. = Timeline support 支持时间轴 .S. = Slice t ...
- http://www.cnblogs.com/xwdreamer/archive/2012/02/21/2360818.html
http://www.cnblogs.com/xwdreamer/archive/2012/02/21/2360818.html
随机推荐
- python之路——7
王二学习python的笔记以及记录,如有雷同,那也没事,欢迎交流,wx:wyb199594 复习 1. 小数据池 int -5---256 str 特殊字符 *202. ASCII码 8位 1字节 - ...
- Linux背背背(4)vim操作
目录 1.打开文件 2.vim的三种模式 3.扩展 (关于vi 和 vim 的区别,它们都是多模式编辑器,不同的是vim 是vi的升级版本,它不仅兼容vi的所有指令,而且还有一些新的特性在里面.) 1 ...
- Oracle 唯一 约束(unique constraint) 与 索引(index) 关系说明
一. 官网对Unique Constraints说明 http://download.oracle.com/docs/cd/E11882_01/server.112/e16508/datainte.h ...
- BeanUtils接口和类
Jakarta Commons项目提供了相当丰富的API,我们之前了解到的Commons Lang只是众多API的比较核心的一小部分而已.Commons下面还有相当数量的子项目,用于解决各种各样不 ...
- 到底什么是哈希Hash?
知识点总结 ---------------------------------------------------------------------------------------------- ...
- i++ 是线程安全的吗?
相信很多中高级的 Java 面试者都遇到过这个问题,很多对这个不是很清楚的肯定是一脸蒙逼.内心肯定还在质疑,i++ 居然还有线程安全问题?只能说自己了解的不够多,自己的水平有限. 先来看下面的示例来验 ...
- SQL Server事务
事务全部是关于原子性的.原子性的概念是指可以把一些事情当做一个单元来看待.从数据库的角度看,它是指应全部执行或全部都不执行的一条或多条语句的最小组合.为了理解事务的概念,需要能够定义非常明确的边界.事 ...
- Python:笔记1_字符串处理【转载】
[转载自:https://www.cnblogs.com/houht/p/3308634.html] 1. 判断字符串str是否为空Approach 1:如果字符串长度为0,说明字符串为空,code如 ...
- Oracle 关联查询
select count(1),a.policy_id from gp_pol_prod a where a.product_id=8401 group by a.policy_id having c ...
- 转载:oracle 启动过程--oracle深入研究
Oracle数据库的启动-nomount状态深入解析 通常所说的Oracle Server主要由两个部分组成:Instance和Database.Instance是指一组后台进程(在Windows上是 ...