bzoj2300【HAOI2011】防线修建
题目描述
上图中,A,B,C,D,E点为A国城市,且目前都要保护,那么修建的防线就会是A-B-C-D,花费也就是线段AB的长度+线段BC的长度+线段CD的长度,如果,这个时候撤销B点的保护,那么防线变成下图
输入格式
输出格式
对于每个询问输出1行,一个实数v,表示修建防线的花费,保留两位小数
提示
题解:
- 考虑倒着把点插入凸包;
- 只需要每次找到点在原凸包的$x$坐标前驱后继删掉不构成凸包的再插入;
- 可以用$splay$维护即可(常数不太好看)
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<queue>
#include<cmath>
#include<vector>
#include<stack>
#include<map>
#include<set>
#define Run(i,l,r) for(int i=l;i<=r;i++)
#define Don(i,l,r) for(int i=l;i>=r;i--)
#define ll long long
#define ld double
#define inf 0x3f3f3f3f
#define mk make_pair
#define fir first
#define sec second
#define il inline
#define rg register
#define pb push_back
using namespace std;
const int N=;
int n,m,mx,tx,ty,ch[N][],sz[N],fa[N],vis[N],rt,cnt;
ld now,ans[N<<];
il char gc(){
static char*p1,*p2,s[];
if(p1==p2)p2=(p1=s)+fread(s,,,stdin);
return(p1==p2)?EOF:*p1++;
}
il int rd(){
int x=; char c=gc();
while(c<''||c>'')c=gc();
while(c>=''&&c<='')x=(x<<)+(x<<)+c-'',c=gc();
return x;
}
struct poi{
int x,y;
poi(int _x=,int _y=):x(_x),y(_y){};
bool operator <(const poi&A)const{return x==A.x?y<A.y:x<A.x;}
poi operator -(const poi&A)const{return poi(x-A.x,y-A.y);}
}p[N],q[N],Q[N<<];
int crs(poi A,poi B){return A.x*B.y-A.y*B.x;}
int dot(poi A,poi B){return A.x*B.x+A.y*B.y;}
ld dis(poi A){return sqrt(A.x*A.x+A.y*A.y);}
il void update(int x){sz[x]=sz[ch[x][]]+sz[ch[x][]]+;}
il void rotate(int x,int&k){
int y=fa[x],z=fa[y];
if(y==k)k=x;else ch[z][ch[z][]==y]=x;
int l=ch[y][]==x,r=l^;
fa[x]=z;fa[y]=x;fa[ch[x][r]]=y;
ch[y][l]=ch[x][r],ch[x][r]=y;
update(y);update(x);
}
il void splay(int x,int&k){
for(int y,z;x!=k;rotate(x,k)){
y=fa[x],z=fa[y];
if(y!=k)rotate( (ch[y][]==x)^(ch[z][]==y) ? x : y ,k);
}
}
il void ins(int&k,int x){
if(!k)q[k=++cnt]=p[x];
else {
if(p[x]<q[k])ins(ch[k][],x),fa[ch[k][]]=k;
else ins(ch[k][],x),fa[ch[k][]]=k;
}
update(k);
}
il int find_pre(int k,int x){
int re=;
while(k){
if(q[k]<p[x])re=k,k=ch[k][];
else k=ch[k][];
}
return re;
}
il int find_nxt(int k,int x){
int re=;
while(k){
if(p[x]<q[k])re=k,k=ch[k][];
else k=ch[k][];
}
return re;
}
il void insert(int x){
int T1=find_pre(rt,x),T2=find_nxt(rt,x),t1,t2;
if(crs(p[x]-q[T1],q[T2]-p[x])>=)return;
now -= dis(q[T1]-q[T2]);
for(splay(t1=T1,rt),t2=ch[t1][];sz[t2];){
while(ch[t2][])t2=ch[t2][];
splay(t2,ch[t1][]);
if(crs(q[t1]-q[t2],p[x]-q[t1])>=){
now -= dis(q[t1]-q[t2]);
fa[ch[t2][]=ch[t1][]]=t2;
update(rt=t2);
t1=t2,t2=ch[t1][];
}else break;
}
now += dis(p[x]-q[t1]);
for(splay(t1=T2,rt),t2=ch[t1][];sz[t2];){
while(ch[t2][])t2=ch[t2][];
splay(t2,ch[t1][]);
if(crs(q[t1]-q[t2],p[x]-q[t1])<=){
now -= dis(q[t1]-q[t2]);
fa[ch[t2][]=ch[t1][]]=t2;
update(rt=t2);
t1=t2,t2=ch[t1][];
}else break;
}
now += dis(p[x]-q[t1]);
ins(rt,x);
}
int main(){
#ifndef ONLINE_JUDGE
freopen("bzoj2300.in","r",stdin);
freopen("bzoj2300.out","w",stdout);
#endif
mx=rd();tx=rd();ty=rd();n=rd();
for(int i=;i<=n;++i)p[i].x=rd(),p[i].y=rd();
p[]=poi(,);ins(rt,);
p[n+]=poi(mx,);ins(rt,n+);
p[n+]=poi(tx,ty);ins(rt,n+);
now = dis(p[]-p[n+]) + dis(p[n+]-p[n+]);
m=rd();for(int i=;i<=m;++i){Q[i].x=rd();if(Q[i].x&)vis[Q[i].y=rd()]=;}
for(int i=;i<=n;++i)if(!vis[i])insert(i);
for(int i=m;i;--i)if(Q[i].x&)insert(Q[i].y);else ans[i]=now;
for(int i=;i<=m;++i)if(Q[i].x==)printf("%.2lf\n",ans[i]);
return ;
}//by tkys_Austin;bzoj2300
bzoj2300【HAOI2011】防线修建的更多相关文章
- bzoj千题计划236:bzoj2300: [HAOI2011]防线修建
http://www.lydsy.com/JudgeOnline/problem.php?id=2300 维护动态凸包,人懒用的set 用叉积判断,不要用斜率 #include<set> ...
- BZOJ2300[HAOI2011]防线修建——非旋转treap+凸包(平衡树动态维护凸包)
题目描述 近来A国和B国的矛盾激化,为了预防不测,A国准备修建一条长长的防线,当然修建防线的话,肯定要把需要保护的城市修在防线内部了.可是A国上层现在还犹豫不决,到底该把哪些城市作为保护对象呢?又由于 ...
- BZOJ2300: [HAOI2011]防线修建
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2300 (我只是在发以前写过的题.. 因为题目没说强制在线,所以离线乱搞就可以了.先把点删掉然后 ...
- 2019.02.21 bzoj2300: [HAOI2011]防线修建(set+凸包)
传送门 题意:动态维护凸包周长. 思路: 见这篇求面积的吧反正都是一个套路. 代码: #include<bits/stdc++.h> #define int long long #defi ...
- 【BZOJ2300】[HAOI2011]防线修建 set维护凸包
[BZOJ2300][HAOI2011]防线修建 Description 近来A国和B国的矛盾激化,为了预防不测,A国准备修建一条长长的防线,当然修建防线的话,肯定要把需要保护的城市修在防线内部了.可 ...
- 【BZOJ 2300】 2300: [HAOI2011]防线修建 (动态凸包+set)
2300: [HAOI2011]防线修建 Description 近来A国和B国的矛盾激化,为了预防不测,A国准备修建一条长长的防线,当然修建防线的话,肯定要把需要保护的城市修在防线内部了.可是A国上 ...
- BZOJ 2300: [HAOI2011]防线修建( 动态凸包 )
离线然后倒着做就变成了支持加点的动态凸包...用平衡树维护上凸壳...时间复杂度O(NlogN) --------------------------------------------------- ...
- [luogu P2521] [HAOI2011]防线修建
[luogu P2521] [HAOI2011]防线修建 题目描述 近来A国和B国的矛盾激化,为了预防不测,A国准备修建一条长长的防线,当然修建防线的话,肯定要把需要保护的城市修在防线内部了.可是A国 ...
- P2521 [HAOI2011]防线修建
题目链接:P2521 [HAOI2011]防线修建 题意:给定点集 每次有两种操作: 1. 删除一个点 (除开(0, 0), (n, 0), 与指定首都(x, y)) 2. 询问上凸包长度 至于为什么 ...
- 【题解】P2521 [HAOI2011]防线修建(动态凸包)
[题解]P2521 [HAOI2011]防线修建(动态凸包) 凸包是易插入不好删除的东西,按照剧情所以我们时光倒流 然后问题就是维护凸包的周长,支持加入 本来很简单,但是计算几何就是一些小地方经验不足 ...
随机推荐
- DataRow对象的RowState和DataRowVersion属性特点
DataRow对象有两个比较重要的属性,分别是行状态(RowState)和行版本(DataRowVersion),通过这两个属性能够有效的管理表中的行.下面简要的介绍一下行状态和行版本的特点和关系. ...
- NABCD模型分析
1.N——need需求 目前,学习英语是所有学生会面临的问题.提高词汇量对学习英语是十分必要的,尤其是对大学生来说对手机的使用特别频繁,我们提高英语词汇量也应该把手机更好的利用起来,利用自己对手机的使 ...
- Java每日编程day2
Java每日编程day2 第一题 package com.pcx.day2; /* * 九九乘法表并逆序 */ public class JiuJiu { public static void mai ...
- 凡事预则立|项目Beta冲刺准备
1.讨论组长是否重选的议题和结论. 组员一致认为组长不需要重选,我们都很认可组长的表现,组长的付出我们都看在眼里,我们找不出更适合担任组长的人选. 2.下一阶段需要改进完善的功能. 财富值的布局优化以 ...
- 如何:通过将HTML编码应用于字符串来防止Web应用程序中的脚本漏洞
当用户可以将可执行代码(或脚本)添加到您的应用程序中时,会发生大多数脚本攻击.默认情况下,ASP.NET提供请求验证,如果表单发布包含任何HTML,则会引发错误. 您可以通过以下方式帮助防止脚本漏洞利 ...
- 批量梯度下降(BGD)、随机梯度下降(SGD)以及小批量梯度下降(MBGD)的理解
梯度下降法作为机器学习中较常使用的优化算法,其有着三种不同的形式:批量梯度下降(Batch Gradient Descent).随机梯度下降(Stochastic Gradient Descent ...
- Java通用oracle和mysql数据库连接
Java中oracle数据库连接写一个通用类UBUtil(){} import java.io.InputStream; import java.sql.*; import java.util.Pro ...
- 个人作业-week3案例分析
第一部分 软件调研测评(必应词典移动端) 找到的bug: 在词汇量测试中每个单词给用户思考的时间太短,只有五秒钟.导致很多似曾相识的单词还没来得及想起就已经过了.如果说测的是用户记忆深刻的单词,那些记 ...
- JMeter性能测试基础 (1) - 安装及简单使用
Apache JMeter是一款开源性能测试工具,全部功能使用Java编写,可用于进行性能测试.JMeter最初被设计用于Web应用测试,之后被扩展至多个测试领域. Apache jmeter 可以用 ...
- syntax error:unexpected end of file
将window上编辑的xxy1.sh脚本上传到linux上,并执行的时候提示 xxy1.sh: line 17: syntax error: unexpected end of file 但是通过ca ...