题目描述

维护一个向量集合,在线支持以下操作:
"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】向量集的更多相关文章

  1. BZOJ3533 [Sdoi2014]向量集 【线段树 + 凸包 + 三分】

    题目链接 BZOJ3533 题解 我们设询问的向量为\((x_0,y_0)\),参与乘积的向量为\((x,y)\) 则有 \[ \begin{aligned} ans &= x_0x + y_ ...

  2. bzoj3533: [Sdoi2014]向量集

    Description 维护一个向量集合,在线支持以下操作:"A x y (|x|,|y| < =10^8)":加入向量(x,y);" Q x y l r (|x| ...

  3. BZOJ3533:[SDOI2014]向量集(线段树,三分,凸包)

    Description 维护一个向量集合,在线支持以下操作: "A x y (|x|,|y| < =10^8)":加入向量(x,y); " Q x y l r (| ...

  4. BZOJ 3533: [Sdoi2014]向量集( 线段树 + 三分 )

    答案一定是在凸壳上的(y>0上凸壳, y<0下凸壳). 线段树维护, 至多N次询问, 每次询问影响O(logN)数量级的线段树结点, 每个结点O(logN)暴力建凸壳, 然后O(logN) ...

  5. 【bzoj3533】[Sdoi2014]向量集 线段树+STL-vector维护凸包

    题目描述 维护一个向量集合,在线支持以下操作:"A x y (|x|,|y| < =10^8)":加入向量(x,y);"Q x y l r (|x|,|y| < ...

  6. bzoj 3533: [Sdoi2014]向量集 线段树维护凸包

    题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=3533 题解: 首先我们把这些向量都平移到原点.这样我们就发现: 对于每次询问所得到的an ...

  7. bzoj 3533 [Sdoi2014]向量集 线段树+凸包+三分(+动态开数组) 好题

    题目大意 维护一个向量集合,在线支持以下操作: "A x y (|x|,|y| < =10^8)":加入向量(x,y); "Q x y l r (|x|,|y| & ...

  8. Sdoi2014 向量集

    题目描述 题解: 码力太差重构之后才$A……$ 首先求向量点积最大很容易想到凸包, 设已知$(x_0,y_0)$,求$(x,y)$满足$(x,y)*(x_0,y_0)>=(x',y')*(x_0 ...

  9. P3309 [SDOI2014]向量集

    传送门 达成成就:一人独霸三页提交 自己写的莫名其妙MLE死都不知道怎么回事,照着题解打一直RE一个点最后发现竟然是凸包上一个点求错了--四个半小时就一直用来调代码了-- 那么我们只要维护好这个凸壳, ...

  10. SDOI 2014 向量集

    [SDOI2014]向量集 题目描述 维护一个向量集合,在线支持以下操作: - "A x y (|x|,|y| < =10^8)":加入向量(x,y); - " Q ...

随机推荐

  1. CUDA、CUDNN在Mac Book Pro上安装的问题

    由于原版MacOS自带Nvidia驱动版本过低,导致最新版本CUDA安装后无法运行.具体症状为:在编译时一切正常,在运行CUDA相关程序时报错: CUDA driver version is insu ...

  2. Tomcat分析

    最近闲来无事,总结了一下tomcat的一些知识,分享出来供大家参考,如有错误,请及时与我联系. 1. 入门示例:虚拟主机提供web服务 该示例通过设置虚拟主机来提供web服务,因为是入门示例,所以设置 ...

  3. DockerCon2017前瞻 - Docker企业版体验

    DockerCon 2017将于四月17号在美国Austin召开.在去年DockerCon上,Docker公司一系列的发布吹响了进军企业市场的号角.今天,容器技术已经愈发成熟,被越来越多的企业所关注和 ...

  4. lscpi命令详解

    基础命令学习目录 lspci是一个用来查看系统中所有PCI总线以及连接到该总线上的设备的工具. 命令格式为 lspci -参数 (不加参数显示所有硬件设备) 至于有哪些参数及其详细用法可以看下这篇博客 ...

  5. 马赛克是否无法逆转?Python简单消除,看片无忧!

    图片水印,轻松去除 前段时间玩过了全民K歌,不知道大家是否玩过,还是做得挺好的,就我这嗓子都能唱出张学友的味道,其中更是有消除噪声的功能,就是朋友们都在吃鸡大叫,我在旁边唱歌依然不受影响. 既然声音可 ...

  6. java第二次试验报告

    北京电子科技学院(BESTI) 实     验    报     告 课程:Java程序设计   班级:1353       姓名:郭皓  学号:20135327 成绩:             指导 ...

  7. crontab任务不生效

    新建php脚本ctTest.php,代码如下: <?php /****************************************************************** ...

  8. Servlet学习小结

    最近有点小累啊,上课平均一天6小时,再去修一修代码就没什么多的时间了.现在写我最近学习的成果:想想最近软件工程老师留的题目,我还有一些重要的地方没有想清楚.题目是这样的:生成四则运算的题目,算术题目包 ...

  9. stateful openflow------整理openstate原理以及具体应用

    openstate基本思想就是控制器下放一部分功能,交换机不再是简单的dumb,而是保留一些简单的wise. 论文中以端口锁定为例,提出了米粒型状态机在交换机内部的应用从而可以大大减少交换机和控制器之 ...

  10. python learning Exception & Debug.py

    ''' 在程序运行的过程中,如果发生了错误,可以事先约定返回一个错误代码,这样,就可以知道是否有错,以及出错的原因.在操作系统提供的调用中,返回错误码非常常见.比如打开文件的函数open(),成功时返 ...