BZOJ 2648: SJY摆棋子(K-D Tree)
Time Limit: 20 Sec Memory Limit: 128 MB
Submit: 6051 Solved: 2113
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 1
2 3
2 1 2
1 3 3
2 4 2
Sample Output
2
HINT
kdtree可以过
Source
K-D Tree裸题
洛谷上需要拍扁重构才能过
丧心病狂
#include<cstdio>
#include<algorithm>
#define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1 << 17, stdin), p1 == p2) ? EOF : *p1++)
using namespace std;
const int MAXN = * 1e5 + , INF = 1e9 + ;
const double delat = 0.60;
char buf[ << ], *p1 = buf, *p2 = buf;
inline int read() {
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * f;
}
int N, M, WD, root, Ans;
inline int abs(int x) {
return x < ? -x : x;
}
#define ls(x) T[x].ls
#define rs(x) T[x].rs
struct Point {
int x[];
bool operator < (const Point rhs) const {
return x[WD] < rhs.x[WD];
}
}p[MAXN];
struct Node {
int ls, rs, siz, mi[], mx[];
Point tp;
}T[MAXN];
int rub[MAXN], top, cur;
int NewNode() {
return top ? rub[top--] : ++cur;//tag
}
void update(int k) {
T[k].siz = T[ls(k)].siz + T[rs(k)].siz + ;
for(int i = ; i <= ; i++) {
T[k].mi[i] = T[k].mx[i] = T[k].tp.x[i];
if(ls(k)) T[k].mi[i] = min(T[k].mi[i], T[ls(k)].mi[i]), T[k].mx[i] = max(T[k].mx[i], T[ls(k)].mx[i]);
if(rs(k)) T[k].mi[i] = min(T[k].mi[i], T[rs(k)].mi[i]), T[k].mx[i] = max(T[k].mx[i], T[rs(k)].mx[i]);
}
}
int Build(int l, int r, int wd) {
if(l > r) return ;
int k = NewNode(), mid = l + r >> ;
WD = wd, nth_element(p + l, p + mid, p + r + );
T[k].tp = p[mid];
T[k].ls = Build(l, mid - , wd ^ );
T[k].rs = Build(mid + , r, wd ^ );
update(k);
return k;
}
inline void Apart(int k, int num) {
if(T[k].ls) Apart(ls(k), num);
p[num + T[ls(k)].siz + ] = T[k].tp, rub[++top] = k;
if(T[k].rs) Apart(rs(k), num + T[ls(k)].siz + );
}
inline int check(int &k, int wd) {
if(T[k].siz * delat < T[ls(k)].siz || T[k].siz * delat < T[rs(k)].siz)
Apart(k, ), k = Build(, T[k].siz, wd);
}
void Insert(Point a, int &k, int wd) {
if(k == ) {
k = NewNode(); T[k].tp = a; update(k); return ;
}
if(a.x[wd] < T[k].tp.x[wd]) Insert(a, ls(k), wd ^ );
else Insert(a, rs(k), wd ^ );
update(k); check(k, wd);
}
inline int dis(Point a, Point b) {
return abs(a.x[] - b.x[]) + abs(a.x[] - b.x[]);
}
inline int Manha(Point a, int b) {
int rt = ;
for(int i = ; i <= ; i++)
rt += max(, a.x[i] - T[b].mx[i]) + max(, T[b].mi[i] - a.x[i]);
return rt;
}
int Query(Point a, int k) {
Ans = min(Ans, dis(T[k].tp, a));
int disl = INF, disr = INF;
if(ls(k)) disl = Manha(a, T[k].ls);
if(rs(k)) disr = Manha(a, T[k].rs);
if(disl < disr) {
if(disl < Ans) Query(a, ls(k));
if(disr < Ans) Query(a, rs(k));
}
else {
if(disr < Ans) Query(a, rs(k));
if(disl < Ans) Query(a, ls(k));
}
}
int main() {
#ifdef WIN32
freopen("a.in", "r", stdin);
#endif
N = read(); M = read();
for(int i = ; i <= N; i++)
p[i].x[] = read(), p[i].x[] = read();
root = Build(, N, );
while(M--) {
int opt = read(), x = read(), y = read();
if(opt == )
Insert((Point){x, y}, root, );
else
Ans = INF + , Query((Point){x, y}, root), printf("%d\n", Ans);
}
return ;
}
BZOJ 2648: SJY摆棋子(K-D Tree)的更多相关文章
- BZOJ 2648 SJY摆棋子(KD Tree)
http://www.lydsy.com/JudgeOnline/problem.php?id=2648 题意: 思路: KDtree模板题. 参考自http://www.cnblogs.com/ra ...
- BZOJ 2648: SJY摆棋子
2648: SJY摆棋子 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 2968 Solved: 1011[Submit][Status][Disc ...
- BZOJ 2648: SJY摆棋子 kdtree
2648: SJY摆棋子 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2648 Description 这天,SJY显得无聊.在家自己玩 ...
- bzoj 2648: SJY摆棋子&&2716: [Violet 3]天使玩偶 --kdtree
2648: SJY摆棋子&&2716: [Violet 3]天使玩偶 Time Limit: 20 Sec Memory Limit: 128 MB Description 这天,S ...
- bzoj 2648 SJY摆棋子——KDtree
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2648 第一道KDtree! 学习资料:https://blog.csdn.net/zhl30 ...
- BZOJ 2648 SJY摆棋子 ——KD-Tree
[题目分析] KD-Tree第一题,其实大概就是搜索剪枝的思想,在随机数据下可以表现的非常好NlogN,但是特殊数据下会达到N^2. 精髓就在于估价函数get以及按照不同维度顺序划分的思想. [代码] ...
- bzoj 2648 SJY摆棋子 kd树
题目链接 初始的时候有一些棋子, 然后给两种操作, 一种是往上面放棋子. 另一种是给出一个棋子的位置, 问你离它最近的棋子的曼哈顿距离是多少. 写了指针版本的kd树, 感觉这个版本很好理解. #inc ...
- bzoj 2648 SJY摆棋子 —— K-D树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2648 学习资料:https://blog.csdn.net/zhl30041839/arti ...
- bzoj 2648: SJY摆棋子【KD-tree】
其实理论上cdq更优 核心是依次取x值.y值的mid作为当前节点,向两边递归建立二叉树,树上维护size:子树大小:mx[0/1]:子树内最大x/y:mn[0/1]:子树内最小x/y:d[0/1]:这 ...
随机推荐
- Java学习笔记(4)----Public,Protected,Package,Private修饰符可见性
Java修饰符类型(public,protected,private,friendly) public的类.类属变量及方法,包内及包外的任何类均可以访问:protected的类.类属变量及方法,包内的 ...
- c++开源日志log4cplus使用开发文档
下载地址:http://files.cnblogs.com/files/lizhigang/LOG4CPLUS%E5%BC%80%E5%8F%91%E4%B8%8E%E4%BD%BF%E7%94%A8 ...
- Breakpoint debugging
断点调试的作用: A:查看程序的执行流程. B:调试程序. package basic.java; public class DebugTest { public static void main(S ...
- java中字节流与字符流以及字节流多余字节问题
1.字节流 字节流byte为单位对文件的数据进行写入与读取操作.字节的方式在复制音频图片文件时比较适用,但在对于普通文件的读写上有两大缺陷: 第一,字节流在读取中文字符时,若设定的字节数组长度刚好末尾 ...
- python 反射 动态导入模块 类attr属性
1.反射 hasattr getattr delattr setattr 优点:事先定义好接口,接口只有在被完成后才能真正执行,这实现了即插即用,这其实是一种“后期绑定”,即先定义好接口, 然后是再去 ...
- 4.Bootstrap基础总结
一.Bootstrap 网格系统 二.Bootstrap 排版 三.Bootstrap 代码 四.Bootstrap 表格 五.Bootstrap 表单 六.Bootstrap 按钮 七.Bootst ...
- 机器学习入门线性回归 岭回归与Lasso回归(二)
一 线性回归(Linear Regression ) 1. 线性回归概述 回归的目的是预测数值型数据的目标值,最直接的方法就是根据输入写出一个求出目标值的计算公式,也就是所谓的回归方程,例如y = a ...
- excel展示
- ArcGIS的网络分析
ArcGIS的网络分析分为两类:传输网络(Network Analyst)和效用网络(Utility Network Analyst). 一.从应用上来考虑: 1.传输网络常用于道路.地铁等交通网络分 ...
- Azure 登录设置
转自 http://blog.csdn.net/azure_nonofficial/article/details/38095459 这是我们Azure非官方的第一篇博文,欢迎大家各种拍砖. 微软云计 ...