#include <cstdio>
#include <cmath>
#include <cstring>
#include <algorithm>
#include <ctime>
#include <cstdlib>
using namespace std;
typedef long long ll;
#define enter putchar('\n')
#define space putchar(' ')
template <class T>
void read(T &x){
char c;
bool op = 0;
while(c = getchar(), c > '9' || c < '0')
if(c == '-') op = 1;
x = c - '0';
while(c = getchar(), c >= '0' && c <= '9')
x = x * 10 + c - '0';
if(op) x = -x;
}
template <class T>
void write(T x){
if(x < 0) putchar('-'), x = -x;
if(x >= 10) write(x / 10);
putchar('0' + x % 10);
} const int N = 1000005, D = 2, INF = 0x3f3f3f3f;
int n, m, tot, curD, root, ans;
int co[N][D], mi[N][D], ma[N][D], ls[N], rs[N];
struct point {
int co[D];
bool operator < (const point &b) const {
return co[curD] < b.co[curD];
}
} a[N];
void update(int fa, int son) {
for(int i = 0; i < D; i++) {
mi[fa][i] = min(mi[fa][i], mi[son][i]);
ma[fa][i] = max(ma[fa][i], ma[son][i]);
}
}
int build(int l, int r, int d) {
curD = d;
int mid = (l + r) >> 1;
nth_element(a + l, a + mid, a + r + 1);
for(int i = 0; i < D; i++)
co[mid][i] = mi[mid][i] = ma[mid][i] = a[mid].co[i];
if(mid > l) ls[mid] = build(l, mid - 1, (d + 1) % D), update(mid, ls[mid]);
if(mid < r) rs[mid] = build(mid + 1, r, (d + 1) % D), update(mid, rs[mid]);
return mid;
}
void insert(int k, int x, int d){
if(co[x][d] <= co[k][d]){
if(!ls[k]) ls[k] = x;
else insert(ls[k], x, (d + 1) % D);
update(k, ls[k]);
}
else{
if(!rs[k]) rs[k] = x;
else insert(rs[k], x, (d + 1) % D);
update(k, rs[k]);
}
}
int mindis(int k, const point &a) {
int ret = 0;
for(int i = 0; i < D; i++)
ret += max(mi[k][i] - a.co[i], 0) + max(a.co[i] - ma[k][i], 0);
return ret;
}
int getdis(int k, const point &a) {
int ret = 0;
for(int i = 0; i < D; i++)
ret += abs(co[k][i] - a.co[i]);
return ret;
}
void query(int k, const point &a) {
ans = min(ans, getdis(k, a));
int ld = INF, rd = INF;
if(ls[k]) ld = mindis(ls[k], a);
if(rs[k]) rd = mindis(rs[k], a);
if(ld <= rd){
if(ld <= ans) query(ls[k], a);
if(rd <= ans) query(rs[k], a);
}
else{
if(rd <= ans) query(rs[k], a);
if(ld <= ans) query(ls[k], a);
}
}
int main() {
read(n), read(m), tot = n;
for(int i = 1; i <= n; i++)
for(int j = 0; j < D; j++)
read(a[i].co[j]);
root = build(1, n, 0);
while(m--){
int op;
read(op), read(a[++tot].co[0]), read(a[tot].co[1]);
if(op == 1) {
for(int i = 0; i < D; i++)
co[tot][i] = mi[tot][i] = ma[tot][i] = a[tot].co[i];
insert(root, tot, 0);
}
else {
ans = INF;
query(root, a[tot]);
write(ans), enter;
}
}
return 0;
}

BZOJ 2648 / 2716 K-D Tree 模板题的更多相关文章

  1. BZOJ 2243 染色 | 树链剖分模板题进阶版

    BZOJ 2243 染色 | 树链剖分模板题进阶版 这道题呢~就是个带区间修改的树链剖分~ 如何区间修改?跟树链剖分的区间询问一个道理,再加上线段树的区间修改就好了. 这道题要注意的是,无论是线段树上 ...

  2. POJ1442-查询第K大-Treap模板题

    模板题,以后要学splay,大概看一下treap就好了. #include <cstdio> #include <algorithm> #include <cstring ...

  3. 【BZOJ 3282】Tree Link Cut Tree模板题

    知道了为什么要换根(changeroot),access后为什么有时要splay,以及LCT的其他操作,算是比较全面的啦吧,,, 现在才知道这些,,,真心弱,,, #include<cstdio ...

  4. BZOJ 3224 普通平衡树(Treap模板题)

    3224: Tyvj 1728 普通平衡树 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 14301  Solved: 6208 [Submit][ ...

  5. BZOJ 2648/2716(SJY把件-KD_Tree)[Template:KD_Tree]

    2648: SJY把件 Time Limit: 20 Sec  Memory Limit: 128 MB Submit: 1180  Solved: 391 [id=2648" style= ...

  6. BZOJ 1208 宠物收养所 | 平衡树模板题

    BZOJ 1208 宠物收养所 我犯过的错误:删除一个节点后没有update新的根节点,导致size错了! #include <cstdio> #include <cmath> ...

  7. POJ 1741.Tree and 洛谷 P4178 Tree-树分治(点分治,容斥版) +二分 模板题-区间点对最短距离<=K的点对数量

    POJ 1741. Tree Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 34141   Accepted: 11420 ...

  8. 【BZOJ 1507】【NOI 2003】&【Tyvj P2388】Editor 块状链表模板题

    2016-06-18 当时关于块状链表的想法是错误的,之前维护的是一个动态的$\sqrt{n}$,所以常数巨大,今天才知道原因TwT,请不要参照这个程序为模板!!! 模板题水啊水~~~ 第一次写块状链 ...

  9. kd-tree注解 &amp; bzoj 2648 &amp; 2716 &amp; 3053 解决问题的方法

    [KD-TREE简介]于SYC1999大神"迷住"下一个.我开始接触这样的算法. 首先.这个概念大概能去百度百科.详细的实施.我在看RZZ的代码长大的. 我们能够想象在平面上有N个 ...

随机推荐

  1. SelectObject函数

    SelectObject 函数功能:该函数选择一对象到指定的设备上下文环境中,该新对象替换先前的同样类型的对象. 函数原型:HGDIOBJ SelectObject(HDC hdc, HGDIOBJ ...

  2. 大数据入门第十四天——Hbase详解(三)hbase基本原理与MR操作Hbase

    一.基本原理 1.hbase的位置 上图描述了Hadoop 2.0生态系统中的各层结构.其中HBase位于结构化存储层,HDFS为HBase提供了高可靠性的底层存储支持, MapReduce为HBas ...

  3. 《网路对抗》Exp8 WEB基础实践

    20155336<网路对抗>Exp8 WEB基础实践 一.基础问题回答 1.什么是表单 表单是一个包含表单元素的区域,表单元素是允许用户在表单中(比如:文本域.下拉列表.单选框.复选框等等 ...

  4. 汇编 MOVSX与MOVZX 指令

    知识点:  MOVSX符号扩展传送  MOVZX零扩展传送 一.MOVSX与MOVZX格式 MOVSX 操作数A ,操作数B MOVZX 操作数A ,操作数B 相同点:操作数B 空间必须小于 操作 ...

  5. Linux 下的编译安装说明

    https://www.linuxidc.com/Linux/2017-02/140309.htm

  6. cocos2d-x学习记录5——CCTransition场景过渡

    利用CCTransition能够创建出一系列的场景过渡动画,能够使场景切换时更加绚丽丰富. CCTransition派生出很多过渡动画,传入的参数一般包括过渡时间和创建的场景. MyScene.h内容 ...

  7. libgdx相关知识点

    Gdx.graphics.setContinuousRendering(false); 设置图像为非连续自动渲染. 设置Opengl的混合模式,支持alpha属性 Gdx.gl.glBlendFunc ...

  8. centos7 部署 nginx+tomcat+MariaDB 环境并安装安全狗,使用natapp隧道

    jdk安装: -openjdk 参考:https://blog.csdn.net/dhr201499/article/details/81626466 tomcat安装: 使用版本:8.5.37 参考 ...

  9. java 对象是可以判空的

    比如这里存xml,这里判断了一下element是否为空,来避免空指针异常,推荐用guava的optional判空

  10. linux下的yum命令详细介绍

    yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器.基於RPM包管理,能够从指定的服务器自动下载RP ...