bzoj2716: [Violet 3]天使玩偶
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#define maxn 1000005
#define maxk 1000005
using namespace std; int n,m,ans[maxn],sum[maxk],maxx,maxy;
const int inf=maxk*;
struct date{
int op,x,y,id;
}list[maxn],a[maxn]; bool comp(date x,date y){
return x.x<y.x;
} int lowbit(int x){
return x&(-x);
} void add(int x,int y){
for (int i=x;i<=maxy;i+=lowbit(i)){
sum[i]=max(sum[i],y);
}
} int query(int x){
int temp=;
for (int i=x;i>;i-=lowbit(i)){
temp=max(temp,sum[i]);
}
if (!temp) return -inf;
return temp;
} void cdq_solve(int l,int r){
if (l==r) return;
int mid=(l+r)/;
cdq_solve(l,mid),cdq_solve(mid+,r);
sort(a+l,a+mid+,comp),sort(a+mid+,a+r+,comp);
int temp=;
for (int i=l,j=mid+;j<=r;){
for (;a[i].op==&&i<=mid;i++);
for (;a[j].op==&&j<=r;j++);
if (i<=mid&&a[i].x<=a[j].x) temp=i,add(a[i].y,a[i].x+a[i].y),i++;
else if (j<=r) ans[a[j].id]=min(ans[a[j].id],a[j].x+a[j].y-query(a[j].y)),j++;
}
for (int i=l;i<=temp;i++) if (a[i].op==){
for (int j=a[i].y;j<=maxy;j+=lowbit(j)) sum[j]=;
}
} void read(int &x){
x=;int f=;char ch;
for (ch=getchar();ch>''||ch<'';ch=getchar()) if (ch=='-') f=-;
for (;ch>=''&&ch<='';ch=getchar()) x=x*+ch-'';
x*=f;
} int main(){
int op,x,y;
read(n),read(m);
maxx=maxy=,memset(sum,,sizeof(sum));
for (int i=;i<=n+m;i++) ans[i]=inf;
for (int i=;i<=n;i++){
read(x),read(y);
maxx=max(maxx,x),maxy=max(maxy,y);
list[i].op=,list[i].x=x,list[i].y=y;
}
for (int i=n+;i<=n+m;i++){
read(op),read(x),read(y);
list[i].op=op,list[i].x=x,list[i].y=y,list[i].id=i;
maxx=max(maxx,x),maxy=max(maxy,y);
}
maxx++,maxy++;
n+=m;
for (int i=;i<=n;i++) a[i]=list[i];
cdq_solve(,n);
for (int i=;i<=n;i++) a[i]=list[i],a[i].x=maxx-a[i].x;
cdq_solve(,n);
for (int i=;i<=n;i++) a[i]=list[i],a[i].y=maxy-a[i].y;
cdq_solve(,n);
for (int i=;i<=n;i++) a[i]=list[i],a[i].x=maxx-a[i].x,a[i].y=maxy-a[i].y;
cdq_solve(,n);
for (int i=;i<=n;i++) if (list[i].op==) printf("%d\n",ans[i]);
return ;
}
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2716.gif)
.gif)
.gif)
题意:初始时给定平面内n个点的坐标,构成一个点集,以及m个操作,每个操作为一下两种之一:
1.在该点集中加入一个新点;
2.给定一个点的坐标,询问该点集中的点到该点的曼哈顿距离最小值。
做法:第一种做法是裸上k-d tree,现在我还不会写……;
第二种做法是cdq分治+排序+树状数组(+读入优化,因为我有几个同学被卡常了,有没有觉得特别坑-.-),cdq分治的关键就在于如何高效地用第一个区间的修改来更新第二个区间的询问。首先,我们把初始的n个点也当成修改操作,对于一个询问,影响它的修改操作可能在它的左上,右上,左下,右下,我们在这里只考虑左下的情况(因为其他三种用maxx,maxy搞一搞就可以搞到左下方来,这样做并不影响相对距离,即不影响答案),那如何处理修改在询问左下方的情况呢?
我的方法比较辣鸡qaq,跑了75s,rank1可是10s不到啊,捂脸>.<;
对于修改都在左下方了,dist=x-X+y-Y,(x,y)为询问的点的坐标,(X,Y)为修改的点的坐标,式子可化简为dist=(x+y)-(X+Y),(x+y)确定,我们需要统计的就是位于其左下方的点中,横纵坐标之和最大的,这里我们将两个区间中的点分别按x坐标升序排序,在树状数组中更新答案,及时更新询问的答案即可。过程中用两个指针维护即可。
为什么要转化到左下方呢?因为方便插入,和查询,树状数组只能支持查询前缀最大(小)值。
cdq分治+树状数组+排序
bzoj2716: [Violet 3]天使玩偶的更多相关文章
- [BZOJ2716] [Violet 3]天使玩偶(CDQ分治)
[BZOJ2716] [Violet 3]天使玩偶(CDQ分治) 题面 Ayu 在七年前曾经收到过一个天使玩偶,当时她把它当作时间囊埋在了地下.而七年后 的今天,Ayu 却忘了她把天使玩偶埋在了哪里, ...
- bzoj2648SJY摆棋子&&bzoj2716[Violet 3]天使玩偶*
bzoj2648SJY摆棋子 bzoj2716[Violet 3]天使玩偶 题意: 棋盘上有n个棋子,现在有m个操作,一种是加棋子,一种是查询离某个点最近的棋子.n,m≤500000. 题解: 先将已 ...
- 【kd-tree】bzoj2716 [Violet 3]天使玩偶
#include<cstdio> #include<cmath> #include<algorithm> using namespace std; #define ...
- BZOJ2716 [Violet 3]天使玩偶 【CDQ分治】
题目 输入格式 输出格式 输入样例 //样例太长就不贴了.... 输出样例 //见原题 提示 题解 我们将曼哈顿距离式子中的绝对值去掉,每次只考虑x,y比当前点小的更新答案. 为了使所有点都对答案进行 ...
- 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 ...
- BZOJ2648: SJY摆棋子&&2716: [Violet 3]天使玩偶
BZOJ2648: SJY摆棋子 BZOJ2716: [Violet 3]天使玩偶 BZOJ氪金无极限... 其实这两道是同一题. 附上2648的题面: Description 这天,SJY显得无聊. ...
- BZOJ 2716: [Violet 3]天使玩偶
2716: [Violet 3]天使玩偶 Time Limit: 80 Sec Memory Limit: 128 MBSubmit: 1473 Solved: 621[Submit][Statu ...
- BZOJ 2716: [Violet 3]天使玩偶( CDQ分治 + 树状数组 )
先cdq分治, 然后要处理点对答案的贡献, 可以以询问点为中心分成4个区域, 然后去掉绝对值(4种情况讨论), 用BIT维护就行了. --------------------------------- ...
- bzoj 2648: SJY摆棋子&&2716: [Violet 3]天使玩偶 --kdtree
2648: SJY摆棋子&&2716: [Violet 3]天使玩偶 Time Limit: 20 Sec Memory Limit: 128 MB Description 这天,S ...
随机推荐
- DEDECMS之五 单页
在网站开发中经常碰到关于我们.联系方式等简单的页面,那么在DEDECMS中如何实现? 一.效果 以上左侧导航的链接都是单页,右边为内容部分 二.单页的实现 创建频道封来实现 1.常规选项 2.高级选项 ...
- [LINK]php的三种CLI常量:STDIN,STDOUT,STDERR
FROM : http://www.cnblogs.com/thinksasa/archive/2013/02/27/2935158.html PHP CLI(command line interfa ...
- [转]JS调用Android里面的方法,Android调用JS里面的方法
FROM : http://blog.csdn.net/hj563308597/article/details/45197709 Android WebView 在公司Android的开发过程中遇到一 ...
- ssh 免密码设置失败原因总结
先复习一下设置ssh免密码操作的步骤: 进入主目录 cd 生成公钥 ssh-keygen -t rsa -P '' (注:最后是二个单引号,表示不设置密码) 然后分发公钥到目标机器 ssh-copy- ...
- Intel pin 2.14/CentOS 6 X86-64/安装
环境:Intel Pin 2.14 CentOS 6 X86-64 --linux.tar.gz 进入 ./source/tools/ManualExamples make all TARGET=in ...
- 数据挖掘系列(9)——BP神经网络算法与实践
神经网络曾经很火,有过一段低迷期,现在因为深度学习的原因继续火起来了.神经网络有很多种:前向传输网络.反向传输网络.递归神经网络.卷积神经网络等.本文介绍基本的反向传输神经网络(Backpropaga ...
- EMV内核使用中的常见问题
EMV内核在使用上会由于调用不当引起的许多问题,本文旨在基于内核LOG(也就是与IC卡交互的指令LOG)的基础上,对一些常见问题作初步的分析与解答,方便不熟悉EMV规范的同学参考. 本文的前提是你已经 ...
- JSP 4个域对象-9个内置对象-11个EL隐式对象
一. 四大域对象 1. PageContext :页面范围的数据 2. ServletRequest:请求范围的数据 3. HttpSession:会话范围的数据 4. ServletContext: ...
- php json 格式控制
本文同步至我的个人博客:http://www.52cik.com/2015/12/23/php-json-format.html 关于 json 这个问题,陆陆续续有新手朋友找我问,比如为什么我输出的 ...
- Beyond Compare 3 设置自动换行
设置自动换行方法: 在菜单栏里点击“工具”,然后在弹出列表里选择“文件格式”,在弹出框的左下角编辑文件格式默认值中,选择“文本格式”,对右侧的 ‘每行字符限制’进行修改保存即可,一般可设置80或90. ...