http://www.lydsy.com/JudgeOnline/problem.php?id=2716

样例输入

2 3
1 1
2 3
2 1 2
1 3 3
2 4 2

样例输出

1

2

————————————————————————————————

整整一个上午的时间,终于DEBUG出来了,原来是因为我数组开小了……

首先我们很容易想到一个三元组(t,x,y),其中t为操作时间。

默认最开始给定的一些点的操作为插入,且时间优先级均高于其他的点。

那么显然就是三维偏序,CDQ可以上了。

给t排个序,边归并x边树状数组记录y,然后查即可……

但是我们怎么求dis啊?

我们有种玄学的方法叫做分情况讨论。

分成四种情况:

对于(x,y)(x1,y1)的dis:

x+y-(x1+y1)      (x>x1,y>y1)

x-y-(x1-y1)        (x>x1,y<y1)

-x+y-(y1-x1)      (x<x1,y>y1)

-x-y-(-x1-y1)      (x<x1,y<y1)

其中括号内的东西就是我们要用树状数组来维护的东西,显然当括号内的东西最大的时候我们的距离有最小值。

那么就变成了维护区间最大值的问题了,显然树状数组是能够胜任这项工作的。

具体的实现方法看我代码吧……不好描述。

#include<cstdio>
#include<queue>
#include<cctype>
#include<cstring>
#include<vector>
#include<algorithm>
using namespace std;
typedef long long ll;
const int M=;
const int N=;
const int INF=*N;
inline int read(){
int X=,w=;char ch=;
while(!isdigit(ch)){w|=ch=='-';ch=getchar();}
while(isdigit(ch))X=(X<<)+(X<<)+(ch^),ch=getchar();
return w?-X:X;
}
struct rem{
int t;
int x;
int y;
int pos;
}q[*M],tmp[*M];
int m,n,cnt=,ans[M],tree[N],maxy=-;
bool cmp(rem a,rem b){
return (a.t<b.t||(a.t==b.t&&a.x<b.x)||(a.t==b.t&&a.x==b.x&&a.y<b.y)||(a.t==b.t&&a.x==b.x&&a.y==b.y&&a.pos<b.pos));
}
inline int lowbit(int t){return t&(-t);}
void add(int x,int y){
for(int i=x;i<=maxy;i+=lowbit(i))tree[i]=max(tree[i],y);
return;
}
int query(int x){
int res=-INF;
for(int i=x;i>;i-=lowbit(i))res=max(res,tree[i]);
return res;
}
void cdq(int l,int r){
if(l>=r)return;
int mid=(l+r)>>;
cdq(l,mid);cdq(mid+,r);
for(int i=l,j=l,p=mid+;i<=r;i++){
if(j<=mid&&(p>r||q[j].x<=q[p].x))tmp[i]=q[j++];
else tmp[i]=q[p++];
}
///////////
for(int i=l;i<=r;i++){
q[i]=tmp[i];
if(q[i].t<=mid&&!q[i].pos)add(q[i].y,q[i].x+q[i].y);
if(q[i].t>mid&&q[i].pos)ans[q[i].pos]=min(ans[q[i].pos],q[i].x+q[i].y-query(q[i].y));
}
for(int i=l;i<=r;i++){
if(q[i].t<=mid&&!q[i].pos){
for(int j=q[i].y;j<=maxy;j+=lowbit(j))tree[j]=-INF;
}
}
///////////
for(int i=l;i<=r;i++){
if(q[i].t<=mid&&!q[i].pos)add(maxy-q[i].y,q[i].x-q[i].y);
if(q[i].t>mid&&q[i].pos)ans[q[i].pos]=min(ans[q[i].pos],q[i].x-q[i].y-query(maxy-q[i].y));
}
for(int i=l;i<=r;i++){
if(q[i].t<=mid&&!q[i].pos){
for(int j=maxy-q[i].y;j<=maxy;j+=lowbit(j))tree[j]=-INF;
}
}
///////////
for(int i=r;i>=l;i--){
if(q[i].t<=mid&&!q[i].pos)add(q[i].y,q[i].y-q[i].x);
if(q[i].t>mid&&q[i].pos)ans[q[i].pos]=min(ans[q[i].pos],-q[i].x+q[i].y-query(q[i].y));
}
for(int i=l;i<=r;i++){
if(q[i].t<=mid&&!q[i].pos){
for(int j=q[i].y;j<=maxy;j+=lowbit(j))tree[j]=-INF;
}
}
///////////
for(int i=r;i>=l;i--){
if(q[i].t<=mid&&!q[i].pos)add(maxy-q[i].y,-q[i].x-q[i].y);
if(q[i].t>mid&&q[i].pos)ans[q[i].pos]=min(ans[q[i].pos],-q[i].x-q[i].y-query(maxy-q[i].y));
}
for(int i=l;i<=r;i++){
if(q[i].t<=mid&&!q[i].pos){
for(int j=maxy-q[i].y;j<=maxy;j+=lowbit(j))tree[j]=-INF;
}
}
///////////
return;
}
void clear(){
maxy++;
for(int i=;i<=cnt;i++)ans[i]=INF;
for(int i=;i<=maxy;i++)tree[i]=-INF;
return;
}
int main(){
n=read();
m=read();
for(int i=;i<=n;i++){
q[i].x=read()+;
q[i].y=read()+;
q[i].t=i;
maxy=max(maxy,q[i].y);
}
for(int i=n+;i<=m+n;i++){
int w=read();
if(w==){
q[i].x=read()+;
q[i].y=read()+;
q[i].t=i;
maxy=max(maxy,q[i].y);
}else{
q[i].x=read()+;
q[i].y=read()+;
q[i].t=i;
q[i].pos=++cnt;
maxy=max(maxy,q[i].y);
}
}
sort(q+,q+m+n+,cmp);
clear();
cdq(,m+n);
for(int i=;i<=cnt;i++)printf("%d\n",ans[i]);
return ;
}

BZOJ2716:[Violet 3]天使玩偶——题解的更多相关文章

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

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

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

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

  3. 【kd-tree】bzoj2716 [Violet 3]天使玩偶

    #include<cstdio> #include<cmath> #include<algorithm> using namespace std; #define ...

  4. BZOJ2716 [Violet 3]天使玩偶 【CDQ分治】

    题目 输入格式 输出格式 输入样例 //样例太长就不贴了.... 输出样例 //见原题 提示 题解 我们将曼哈顿距离式子中的绝对值去掉,每次只考虑x,y比当前点小的更新答案. 为了使所有点都对答案进行 ...

  5. bzoj2716: [Violet 3]天使玩偶

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

  6. BZOJ2716: [Violet 3]天使玩偶(KD-Tree)

    Description Input Output Sample Input 100 100 81 23 27 16 52 58 44 24 25 95 34 2 96 25 8 14 97 50 97 ...

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

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

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

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

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

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

随机推荐

  1. Intellij IDEA 2017 通过scala工程运行wordcount

    首先是安装scala插件,可以通过idea内置的自动安装方式进行,也可以手动下载可用的插件包之后再通过idea导入. scala插件安装完成之后,新建scala项目,右侧使用默认的sbt 点击Next ...

  2. Spring学习(十二)-----Spring @PostConstruct和@PreDestroy实例

    实现 初始化方法和销毁方法3种方式: 实现标识接口 InitializingBean,DisposableBean(不推荐使用,耦合性太高) 设置bean属性 Init-method destroy- ...

  3. 2019年猪年颁奖典礼、公司年会、跨年晚会、科技会议、年终答谢会之幕布背景展板PSD模板-第三部分

    16套--2019年猪年颁奖典礼.公司年会.跨年晚会.科技会议.年终答谢会之幕布.背景和展板PSD模板,免费颁奖典礼PSD展板背景幕布,下载地址:百度网盘,https://pan.baidu.com/ ...

  4. Appium+python 自动发送邮件(2)(转)

    (原文:https://www.cnblogs.com/fancy0158/p/10056418.html) 移动端执行完测试case之后,通过邮件自动发送测试报告.大体流程如下: 1.通过unitt ...

  5. sql 命令使用简单记录

    半个月前就想记下用过的SQL命令的!!!     主题: 按时间查询: https://blog.csdn.net/hejpyes/article/details/41863349   左关联: se ...

  6. Python中元祖,列表,字典的区别

    Python中有3种內建的数据结构:列表.元祖和字典: 1.列表 list是处理一组有序项目的数据结构,即你可以在一个列表中存储一个序列的项目. 列表中的项目应该包括在方括号中,这样Python就知道 ...

  7. Windows和Linux系统如何退出python命令行

    python命令行是新手学习python过程中必须要学的一个工具,下面我们来看一下怎么退出python命令行. 第一种方式: 使用python提供的exit()函数,linux平台和windows平台 ...

  8. 基于kcp,consul的service mesh实现

    名字kmesh 技术:proxy,kcp,consul proxy proxy分为前端和后端 前端代理服务层,包括外部的service 后端实现负债均衡 kcp kcp 基于udp,能够实现快速的传输 ...

  9. java处理大文本2G以上

    面试中经常碰到类似问题,问题的关键我觉得是用设置一个缓冲区 还有一个思路 是通过Linux split 命令将文件直接切割成小文件,再进行处理再汇总. 或者jdk7提供的 forkjoin 框架,利用 ...

  10. Android 6.0 中的 Wifi 连接

    Android 6.0 中的 Wifi 连接 这几天在写一个软件,结果被其中的 wifi 连接问题困扰了 3 天. 先描述下需求: usb 接口接了一根 usb2serial,通过这个接口接收命令 当 ...