bzoj3533【Sdoi2014】向量集
题目描述
维护一个向量集合,在线支持以下操作:
"A x y (|x|,|y| < =10^8)":加入向量(x,y);
" Q x y l r (|x|,|y| < =10^8,1 < =L < =R < =T,其中T为已经加入的向量个数)询问第L个到第R个加入的向量与向量(x,y)的点积的最大值。
集合初始时为空
输入格式
输入的第一行包含整数N和字符s,分别表示操作数和数据类别;
接下来N行,每行一个操作,格式如上所述。
请注意s≠'E'时,输入中的所有整数都经过了加密。你可以使用以下程序
得到原始输入:
inline int decode (int x long long lastans) {
return x ^ (lastans & Ox7fffffff);
}
function decode
begin
其中x为程序读入的数,lastans为之前最后一次询问的答案。在第一次询问之前,lastans=0。
注:向量(x,y)和(z,W)的点积定义为xz+yw。
输出格式
对每个Q操作,输出一个整数表示答案。
提示
1 < =N < =4×10^5
新加数据一组..2015.315
题解
- 设当前向量为$(a,b)$集合中向量为$(x,y)$,设$z = ax+by$,有$y = - \frac{a}{b} x + \frac{z}{b}$
- 最优化$z$:
- 当$b>0$即求过集合$S$中的某个点且斜率为$ - \frac{a}{b}$的直线$y$截距最大的为哪条,答案一定在上凸包上;
- 同理$b<0$时求截距最小的为哪条;
- $b==0$随便哪条查即可;
- 如果维护了区间$[L,R]$的凸包就可以在里面三分;
- 应该是可以用线段树套$splay$参照$bzoj2300$但是效率比较低;
- 考虑直接用线段树,由于标号是顺序更新,所以一段区间的最后一个点被加入后再求区间的凸包,查询线段树查询+三分;
- 实现上凸包的排序可以用归并,(然而并没有快TAT);
- O(n \ log^2 \ n )
#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 long double
#define mk make_pair
#define fir first
#define sec second
#define il inline
#define rg register
#define pb push_back
#define ls (k<<1)
#define rs (k<<1|1)
using namespace std;
const int N=;
const ll inf=1e18;
int n,cnt,sz[N<<],L[][N<<],R[][N<<];
ll ans=;
struct poi{
ll x,y;
poi(int _x=,int _y=):x(_x),y(_y){};
poi operator-(const poi&A)const{return poi(x-A.x,y-A.y);}
bool operator <(const poi&A)const{return x==A.x?y<A.y:x<A.x;}
}con[][N],Q,tmp[][N],p[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=,f=; char c=gc();
while(c<''||c>''){if(c=='-')f=-;c=gc();}
while(c>=''&&c<='')x=(x<<)+(x<<)+c-'',c=gc();
return x*f;
}
il ll dot(poi A,poi B){return (ll)A.x*B.x+(ll)A.y*B.y;}
il ll crs(poi A,poi B){return (ll)A.x*B.y-(ll)A.y*B.x;}
il ll max(ll x,ll y){return x>y?x:y;}
il void build(int k,int d,int l,int r){
int mid=(l+r)>>,idl=l,idr=mid+,id=l,top,lst;
for(;idl<=mid||idr<=r;){
if(idr>r||(idl<=mid&&tmp[d+][idl]<tmp[d+][idr]))
tmp[d][id]=tmp[d+][idl],id++,idl++;
else
tmp[d][id]=tmp[d+][idr],id++,idr++;
}
con[d][L[][k]=top=l]=tmp[d][l];
for(rg int i=l+;i<=r;++i){
while(top>l&&crs(con[d][top]-con[d][top-],tmp[d][i]-con[d][top])<=)top--;
con[d][++top]=tmp[d][i];
}
R[][k]=L[][k]=lst=top;
for(rg int i=r-;i>=l;--i){
while(top>lst&&crs(con[d][top]-con[d][top-],tmp[d][i]-con[d][top])<=)top--;
if(i!=l)con[d][++top]=tmp[d][i];
}
R[][k]=top;
}
il void ask(int k,int d,int typ){
int l=L[typ][k],r=R[typ][k];
while(r-l>=){
int mid=(r-l)/,mid1=l+mid,mid2=r-mid;
if(dot(con[d][mid1],Q)<dot(con[d][mid2],Q))l=mid1;
else r=mid2;
}
for(rg int i=l;i<=r;++i)ans=max(ans,dot(con[d][i],Q));
ans=max(ans,dot(con[d][L[][k]],Q));
}
il void update(int k,int d,int l,int r,int x){
if(l==r){
sz[k]=;
L[][k]=L[][k]=R[][k]=R[][k]=x;
tmp[d][x]=con[d][x]=p[x];
}
else{
int mid=(l+r)>>;
if(x<=mid)update(ls,d+,l,mid,x);
else update(rs,d+,mid+,r,x);
sz[k]=sz[ls]+sz[rs];
if(sz[k]==r-l+)build(k,d,l,r);
}
}
il void query(int k,int d,int l,int r,int x,int y){
if(l==x&&r==y){ask(k,d,Q.y>);}
else{
int mid=(l+r)>>;
if(y<=mid)query(ls,d+,l,mid,x,y);
else if(x>mid)query(rs,d+,mid+,r,x,y);
else query(ls,d+,l,mid,x,mid),query(rs,d+,mid+,r,mid+,y);
}
}
int main(){
#ifndef ONLINE_JUDGE
freopen("bzoj3533.in","r",stdin);
freopen("bzoj3533.out","w",stdout);
#endif
char ch,tp;int x,y,l,r;
n=rd();tp=gc();
while(!isalpha(tp))tp=gc();
for(rg int i=;i<=n;++i){
ch=gc();while(!isalpha(ch))ch=gc();
if(ch=='A'){
x=rd();y=rd();
if(tp!='E')x^=ans,y^=ans;
p[++cnt]=poi(x,y);
update(,,,n,cnt);
}else{
x=rd();y=rd();l=rd();r=rd();
if(tp!='E')x^=ans,y^=ans,l^=ans,r^=ans;
Q=(poi){x,y};
ans = -inf;
query(,,,n,l,r);
printf("%lld\n",ans);
ans &= 0x7fffffff;
}
}
return ;
}//by tkys_Austin;
bzoj3533
bzoj3533【Sdoi2014】向量集的更多相关文章
- BZOJ3533 [Sdoi2014]向量集 【线段树 + 凸包 + 三分】
题目链接 BZOJ3533 题解 我们设询问的向量为\((x_0,y_0)\),参与乘积的向量为\((x,y)\) 则有 \[ \begin{aligned} ans &= x_0x + y_ ...
- bzoj3533: [Sdoi2014]向量集
Description 维护一个向量集合,在线支持以下操作:"A x y (|x|,|y| < =10^8)":加入向量(x,y);" Q x y l r (|x| ...
- BZOJ3533:[SDOI2014]向量集(线段树,三分,凸包)
Description 维护一个向量集合,在线支持以下操作: "A x y (|x|,|y| < =10^8)":加入向量(x,y); " Q x y l r (| ...
- BZOJ 3533: [Sdoi2014]向量集( 线段树 + 三分 )
答案一定是在凸壳上的(y>0上凸壳, y<0下凸壳). 线段树维护, 至多N次询问, 每次询问影响O(logN)数量级的线段树结点, 每个结点O(logN)暴力建凸壳, 然后O(logN) ...
- 【bzoj3533】[Sdoi2014]向量集 线段树+STL-vector维护凸包
题目描述 维护一个向量集合,在线支持以下操作:"A x y (|x|,|y| < =10^8)":加入向量(x,y);"Q x y l r (|x|,|y| < ...
- bzoj 3533: [Sdoi2014]向量集 线段树维护凸包
题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3533 题解: 首先我们把这些向量都平移到原点.这样我们就发现: 对于每次询问所得到的an ...
- bzoj 3533 [Sdoi2014]向量集 线段树+凸包+三分(+动态开数组) 好题
题目大意 维护一个向量集合,在线支持以下操作: "A x y (|x|,|y| < =10^8)":加入向量(x,y); "Q x y l r (|x|,|y| & ...
- Sdoi2014 向量集
题目描述 题解: 码力太差重构之后才$A……$ 首先求向量点积最大很容易想到凸包, 设已知$(x_0,y_0)$,求$(x,y)$满足$(x,y)*(x_0,y_0)>=(x',y')*(x_0 ...
- P3309 [SDOI2014]向量集
传送门 达成成就:一人独霸三页提交 自己写的莫名其妙MLE死都不知道怎么回事,照着题解打一直RE一个点最后发现竟然是凸包上一个点求错了--四个半小时就一直用来调代码了-- 那么我们只要维护好这个凸壳, ...
- SDOI 2014 向量集
[SDOI2014]向量集 题目描述 维护一个向量集合,在线支持以下操作: - "A x y (|x|,|y| < =10^8)":加入向量(x,y); - " Q ...
随机推荐
- JavaScript学习要点
Javascript相关内容 1.序列化--json - stringify() 将对象转换为字符串 - parse() 将字符串转换为对象 list=[11,22,33,44,55]; 结果:(5) ...
- Cocos2dx源码赏析(3)之事件分发
Cocos2dx源码赏析(3)之事件分发 这篇,继续从源码的角度赏析下Cocos2dx引擎的另一模块事件分发处理机制.引擎的版本是3.14.同时,也是学习总结的过程,希望通过这种方式来加深对Cocos ...
- Golang 2018.1.2激活及使用技巧
对于做Java开发的同学使用最熟练的开发工具应该当属Eclipse了吧,但是做到后面的话一般都会转用Intellij Idea.至于转用Intellij有什么好处我就不赘述了,简言之就是功能强大,使用 ...
- linux磁盘扩容日志
//针对ext4文件格式的操作系统(如CentOS6):// umount /dev/vdb e2fsck -f /dev/vdb resize2fs /dev/vdb mount /dev/vdb ...
- exec命令详解
基础命令学习目录首页 原文链接: exec: 在bash下输入man exec,找到exec命令解释处,可以看到有”No new process is created.”这样的解释,这就是说exec命 ...
- [linux] lsyncd同步工具
环境说明: 192.168.56.101 同步源 192.168.56.102 同步目标 操作系统centos 7 lsyncd项目地址:https://github.com/axkibe/lsync ...
- No.111_第四次团队会议
后端的偏执 啊,这次又轮到我写团队博客了. 此时又是深夜,窗外漫天繁星.舍友的呼噜声惊吓了月亮,它害羞地跑回了云里去. 我关上灯拔掉机械,悄悄拿着电脑上了床,写这次的团队博客.曾经觉得自己绝对不会晚睡 ...
- No.100_第一次团队会议
任务的确立 这次会议,我们的主要目标是确定任务: 我们的任务有以下几个选择: 学霸网站,这个项目拥有以前的前端代码,我们再使用Django后端服务.上手难度较低,环境较好. 多平台时间管理软件. 安卓 ...
- YQCB冲刺周第五天
站立会议: 任务看板: 今天的任务为依旧为将用户记录的数据添加到数据库中,以及金额球的设置. 遇到的问题为金额球在jsp页面的显示.
- 福大软工1816 · 评分结果 · Alpha冲刺答辩总结
作业地址:https://edu.cnblogs.com/campus/fzu/Grade2016SE/homework/2462 作业提交准则 按时交 - 有分 晚交 - 0分 迟交一周以上 - 倒 ...