不会KD-tree怎么办?CQD硬搞。

建立正常的平面直角坐标系,首先我们只考虑在目标点左下角的点对目标点的贡献,由于左下点的横纵坐标都小于目标点,那么曼哈顿距离就可以化简了,绝对值去掉后,得到$x2+y2-(x1+y1)$,那么我们的目标就转化为了求横纵坐标以及时间轴都小于目标查询点的更改点所作出的贡献,这是一个三维偏序问题,我们在树状数组中维护x+y的最大值,进而即可更新答案。

可是这样做我们只是考虑了左下角点的贡献,肯定是会出错的,但是其余位置的点不容易化简绝对值,或者化简完以后的形式比较难以维护,而且个人认为分类的话码量略大。

那么我们换一个角度,如何将其余位置的点都变化到目标点的左下角。

直接翻转坐标系就行了,把所有点的横纵坐标都翻转一下,使之分别落于其他象限。那么再次调用cdq即可,注意防负下标。

这样打的好处就是比较无脑,而且正确性保障很大,但是常数这种东西还是很神奇的。(本代码不保证Bzoj可A)(其实应该不可A,因为main函数返回值是signed)

#include<bits/stdc++.h>
#define lowbit(x) (x&(-x))
#define int long long
using namespace std;
const int inf=0x7fffffffffffff;
int read(){
int sum=,f=;char x=getchar();
while(x<''||x>''){
if(x=='-') f=-;
x=getchar();
}while(x>=''&&x<=''){
sum=sum*+x-'';
x=getchar();
}return sum*f;
}
struct rec{
int x,y,t,id,ty;
friend bool operator < (const rec &a,const rec &b){
if(a.t==b.t){
if(a.x==b.x) return a.y<b.y;
else return a.x<b.x;
}else return a.t<b.t;
}
}q[],tmp[];
int n,m,kind,Max,ans[],tr[],_time=,mk[];
void change(int pos,int val){
if(!pos) return ;
for(int i=pos;i<=Max;i+=lowbit(i))
if(mk[i]!=_time){
mk[i]=_time;
tr[i]=val;
}
else tr[i]=max(tr[i],val);
}
int ask(int pos){
int ans=-inf;
for(int i=pos;i;i-=lowbit(i))
if(mk[i]==_time) ans=max(ans,tr[i]);
return ans;
}
void cdq(int l,int r){
if(l==r) return ;
int mid=l+r>>;
cdq(l,mid);cdq(mid+,r);
int i=l,j=mid+,tot=l;
while(i<=mid&&j<=r){
if(q[i].x<=q[j].x){
tmp[tot]=q[i];
if(!q[i].ty)
change(q[i].y,q[i].x+q[i].y);
++tot;++i;
}else {
tmp[tot]=q[j];
if(q[j].ty)
ans[q[j].id]=min(ans[q[j].id],q[j].x+q[j].y-ask(q[j].y));
++tot;++j;
}
}
while(i<=mid){
tmp[tot]=q[i];
// if(!q[i].ty)
// change(q[i].y,q[i].x+q[i].y);
++tot;++i;
}
while(j<=r){
tmp[tot]=q[j];
if(q[j].ty)
ans[q[j].id]=min(ans[q[j].id],q[j].x+q[j].y-ask(q[j].y));
++tot;++j;
}
/* for(int i=1;i<=Max;i++)
cout<<tr[i]<<" ";cout<<endl;*/
// for(int k=l;k<=mid;k++)
// if(!q[i].ty) del(q[k].y);
/* for(int i=1;i<=Max;i++)
cout<<tr[i]<<" ";cout<<endl;*/
_time++;
// if(_time>=10000000000) _time=1;
for(int k=l;k<=r;k++) q[k]=tmp[k];
}
signed main(){
n=read();m=read();
for(int i=;i<=n;i++){
q[i].x=read()+;q[i].y=read()+;
q[i].t=;q[i].ty=;
Max=max(Max,max(q[i].x,q[i].y));
}
for(int i=;i<=m;i++){
kind=read();
if(kind&){
q[i+n].x=read()+;q[i+n].y=read()+;
q[i+n].t=i;q[i].ty=;
}else {
q[i+n].x=read()+;q[i+n].y=read()+;
q[i+n].t=i;q[i+n].ty=;
q[i+n].id=++ans[];
ans[ans[]]=inf;
}
Max=max(Max,max(q[i+n].x,q[i+n].y));
}n+=m;
// cout<<"Max="<<Max<<endl;
sort(q+,q+n+);
cdq(,n);
/* for(int i=1;i<=n;i++)
cout<<q[i].t<<" "<<q[i].x<<" "<<q[i].y<<endl;*/
for(int i=;i<=n;i++) q[i].x=-q[i].x+Max+;
sort(q+,q++n);
/* for(int i=1;i<=n;i++)
cout<<q[i].t<<" "<<q[i].x<<" "<<q[i].y<<endl;*/
cdq(,n);
for(int i=;i<=n;i++) q[i].y=-q[i].y+Max+;
sort(q+,q++n);
cdq(,n);
for(int i=;i<=n;i++) q[i].x=-q[i].x+Max+;
sort(q+,q+n+);
cdq(,n);
for(int i=;i<=ans[];i++)
printf("%lld\n",ans[i]);
return ;
}

BZOJ2716天使玩偶的更多相关文章

  1. [BZOJ2716]天使玩偶

    [BZOJ2716]天使玩偶 题目大意: 一个平面直角坐标系,坐标\(1\le x,y\le10^6\).\(n(n\le10^6)\)次操作,操作包含以下两种: 新增一个点\((x,y)\): 询问 ...

  2. [BZOJ2716] [Violet 3]天使玩偶(CDQ分治)

    [BZOJ2716] [Violet 3]天使玩偶(CDQ分治) 题面 Ayu 在七年前曾经收到过一个天使玩偶,当时她把它当作时间囊埋在了地下.而七年后 的今天,Ayu 却忘了她把天使玩偶埋在了哪里, ...

  3. bzoj2648SJY摆棋子&&bzoj2716[Violet 3]天使玩偶*

    bzoj2648SJY摆棋子 bzoj2716[Violet 3]天使玩偶 题意: 棋盘上有n个棋子,现在有m个操作,一种是加棋子,一种是查询离某个点最近的棋子.n,m≤500000. 题解: 先将已 ...

  4. bzoj2716/2648 / P4169 [Violet]天使玩偶/SJY摆棋子

    P4169 [Violet]天使玩偶/SJY摆棋子 k-d tree 模板 找了好几天才发现输出优化错了....真是zz...... 当子树非常不平衡时,就用替罪羊树的思想,拍扁重建. luogu有个 ...

  5. BZOJ2648: SJY摆棋子&&2716: [Violet 3]天使玩偶

    BZOJ2648: SJY摆棋子 BZOJ2716: [Violet 3]天使玩偶 BZOJ氪金无极限... 其实这两道是同一题. 附上2648的题面: Description 这天,SJY显得无聊. ...

  6. BZOJ 2716: [Violet 3]天使玩偶

    2716: [Violet 3]天使玩偶 Time Limit: 80 Sec  Memory Limit: 128 MBSubmit: 1473  Solved: 621[Submit][Statu ...

  7. 【BZOJ-2648&2716】SJY摆棋子&天使玩偶 KD Tree

    2648: SJY摆棋子 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 2459  Solved: 834[Submit][Status][Discu ...

  8. BZOJ 2716: [Violet 3]天使玩偶( CDQ分治 + 树状数组 )

    先cdq分治, 然后要处理点对答案的贡献, 可以以询问点为中心分成4个区域, 然后去掉绝对值(4种情况讨论), 用BIT维护就行了. --------------------------------- ...

  9. CH4701 天使玩偶

    题意 4701 天使玩偶 0x40「数据结构进阶」例题 描述 题目PDF 样例输入 2 3 1 1 2 3 2 1 2 1 3 3 2 4 2 样例输出 1 2 来源 石家庄二中Violet 3杯省选 ...

随机推荐

  1. JTAG各类接口针脚定义、含义以及SWD接线方式

    JTAG有10pin的.14pin的和20pin的,尽管引脚数和引脚的排列顺序不同,但是其中有一些引脚是一样的,各个引脚的定义如下. 一.引脚定义 Test Clock Input (TCK) --- ...

  2. 【转载】Response对象的作用以及常用方法属性

    Response对象是Asp.Net应用程序中非常重要的一个内置对象,其作用为负责将服务器执行好的信息输出给客户端,即作用主要为响应客户端请求并将服务器的响应返回给用户,在页面的临时跳转中,也可使用R ...

  3. elementUI图片墙上传

    elementUI提供了照片墙上传的功能,我们直接拿来用. 以下是实现代码: <template> <div style="padding: 50px;"> ...

  4. OpenWrt增加软件包

    变量名含义 SECTION //包的种类 CATEGORY //显示在menuconfig的哪个目录下 SUBMENU //menuconfig子目录 TITLE //简单的介绍 DESCRIPTIO ...

  5. Story of Jerry Wang's Wechat subscription account

    As an SAP Techinical Ambassador,Jerry is always willing to share his SAP expertise to various social ...

  6. linux7 上安装mongodb4.2.1操作步骤

    MongoDB是一个通用的.基于文档的分布式数据库,它是为现代应用程序开发人员和云时代而构建的.没有数据库能让你更有效率. 1.下载需要的软件包https://www.mongodb.com/down ...

  7. JavaIO模型--装饰者模式

    JavaIO体现出装饰者的设计模式 今天在学SparkRDD之前,听了一堂复习JavaIO的课,觉得讲得不错 Java的IO一直让我觉得一层一层的很麻烦,刚接触的时候,理不太清楚 只知道要分解为输入输 ...

  8. Luogu P2935 最好的地方Best Spot

    Luogu P2935 最好的地方Best Spot 这道题就是一道近乎裸的Floyd,因为数据很小,所以用领接表存图就可以了. #include<bits/stdc++.h> #defi ...

  9. IDEA实用教程(五)——配置IDEA的JVM内存值

    ---恢复内容开始--- 四. 配置IDEA的JVM内存值 IDEA默认配置的JVM内存值比较低,如果硬件配置较高,可以修改该设置. 该设置需要在工程界面进行. 该操作仅建议内存8G以上,64位操作系 ...

  10. python_面向对象——多态

    1.同一接口,多种形态 class Document: def __init__(self,name): self.name = name def show(self): # 异常处理:提示子类必须把 ...