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 ...
随机推荐
- Cocos2dx源码赏析(1)之启动流程与主循环
Cocos2dx源码赏析(1)之启动流程与主循环 我们知道Cocos2dx是一款开源的跨平台游戏引擎,而学习开源项目一个较实用的办法就是读源码.所谓,"源码之前,了无秘密".而笔者 ...
- IIS 无法加载 CSS,JS的问题
IIS 能加载 aspx,但不能加载里面的 js,css ,感觉有点坑. 解决方案如下:http://www.pageadmin.net/article/20121001/479.html 原来是没有 ...
- Hadoop Streaming框架使用(二)
上一篇文章介绍了Streaming的各种参数,本文具体介绍使用方法. 提交hadoop任务示例: $HADOOP_HOME/bin/hadoop streaming \ -input /user/te ...
- 利用cocoapods创建基于git的私有库Spec Repo
上一篇文章记录了我利用cocoapods创建基于SVN的私有库的全部过程,今天我再记录一下基于git创建的过程. 整体先说明一下创建一个私有的podspec包括如下那么几个步骤: 创建并设置一个私有的 ...
- so easy, too happy
一.预估与实际 PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟) Planning 计划 • Estimate • 估计这个任务需要多 ...
- Web应用程序的基本安全实践
创建安全Web应用程序的主题非常广泛.它需要研究以了解安全漏洞.您还需要熟悉Windows..NET框架和ASP.NET的安全设施.最后,有必要了解如何使用这些安全特性来对付威胁. 即使您没有安全方面 ...
- pktgen-dpdk 运行 run.py 报错 Config file 'default' not found 解决方法
pktgen 操作手册:http://pktgen-dpdk.readthedocs.io/en/latest/getting_started.html 执行到这一步时: $ cd <Pktge ...
- Week2:阅读笔记与思考
<构建之法>这本书的内容通俗易懂,每一个知识点都有许多事例佐证,阅读起来不像其他教科书那样枯燥无聊.但阅读过第一.二.十六章之后还是产生了几个疑问,以及更深层次的思考. 第一章 问题1: ...
- 19_集合_第19天(List、Set)_讲义
今日内容介绍 1.List接口 2.Set接口 3.判断集合唯一性原理 非常重要的关系图 xmind下载地址 链接:https://pan.baidu.com/s/1kx0XabmT27pt4Ll9A ...
- Effective Modern C++翻译(5)-条款4:了解如何观察推导出的类型
条款4:了解如何观察推导出的类型 那些想要知道编译器推导出的类型的人通常分为两种,第一种是实用主义者,他们的动力通常来自于软件产生的问题(例如他们还在调试解决中),他们利用编译器进行寻找,并相信这个能 ...