BZOJ 4066 简单题 ——KD-Tree套替罪羊树
【题目分析】
直接x,y二维轮番划分,暴力即可。
套上替罪羊,打碎重构,对于时间复杂度有了保证。
写起来好麻烦,重构的技巧很棒!
【代码】
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> using namespace std; #define maxn 200005 #define inf 0x3f3f3f3f #define lim 0.7 #define L t[o].c[0] #define R t[o].c[1] #define mid (l+r>>1) #define F(i,j,k) for (int i=j;i<=k;++i) struct node{ int d[2],c[2]; int mx[2],mn[2],sum,v,siz,D; int& operator [] (int x){return d[x];} }t[maxn],now; int p[maxn]; int opt=0,D,rt=0,ans=0,tot=0,cnt; inline bool cmp(int x,int y){return t[x][D]<t[y][D];} void pushup(int k) { for (int i=0;i<2;++i) { t[k].mn[i]=min(t[t[k].c[0]].mn[i],min(t[t[k].c[1]].mn[i],t[k].mn[i])); t[k].mx[i]=max(t[t[k].c[0]].mx[i],max(t[t[k].c[1]].mx[i],t[k].mx[i])); } t[k].sum=t[t[k].c[0]].sum+t[t[k].c[1]].sum+t[k].v; t[k].siz=t[t[k].c[0]].siz+t[t[k].c[1]].siz+1; } inline int build(int l,int r,int dir){ D=dir; nth_element(p+l,p+mid,p+r+1,cmp); int o=p[mid]; t[o].D=dir; F(i,0,1) t[o].mn[i]=t[o].mx[i]=t[o][i]; t[o].sum=t[o].v; L=l<mid ? build(l,mid-1,dir^1) : 0; R=mid<r ? build(mid+1,r,dir^1) : 0; pushup(o); return o; } inline void dfs(int o){ if (!o) return; dfs(L); p[++cnt]=o; dfs(R); } inline void rebuild(int &o){ cnt=0; dfs(o); o=build(1,cnt,t[o].D); } void ins(int &o,int dir) { if (!o) { o=++tot; t[o]=now; for (int i=0;i<2;++i) t[o].mn[i]=t[o].mx[i]=t[o].d[i]; t[o].siz=1; t[o].D=dir; t[o].sum=t[o].v; return ; } if (now.d[dir]<t[o].d[dir]) { ins(t[o].c[0],dir^1); pushup(o); if ((double)t[t[o].c[0]].siz>(double)t[o].siz*lim) rebuild(o); } else { ins(t[o].c[1],dir^1); pushup(o); if ((double)t[t[o].c[1]].siz>(double)t[o].siz*lim) rebuild(o); } } void print(int o){ if (!o) return; printf("%d t[o].mn[0]=%d t[o].mn[1]=%d t[o].mx[0]=%d t[o].mx[1]=%d\n",o,t[o].mn[0],t[o].mn[1],t[o].mx[0],t[o].mx[1]); print(L); print(R); } int query(int o,int x1,int y1,int x2,int y2) { if (!o) return 0; if (t[o].mn[0]>=x1 && t[o].mn[1]>=y1 && t[o].mx[0]<=x2 && t[o].mx[1]<=y2) return t[o].sum; else { int ret=0; if (t[o].d[0]>=x1&&t[o].d[0]<=x2&&t[o].d[1]>=y1&&t[o].d[1]<=y2) ret+=t[o].v; if (t[t[o].c[0]].mn[0]>x2||t[t[o].c[0]].mx[0]<x1||t[t[o].c[0]].mn[1]>y2||t[t[o].c[0]].mx[1]<y1); else ret+=query(t[o].c[0],x1,y1,x2,y2); if (t[t[o].c[1]].mn[0]>x2||t[t[o].c[1]].mx[0]<x1||t[t[o].c[1]].mn[1]>y2||t[t[o].c[1]].mx[1]<y1); else ret+=query(t[o].c[1],x1,y1,x2,y2); return ret; } } int main() { for (int i=0;i<2;++i) t[rt].mx[i]=-inf,t[rt].mn[i]=inf; t[rt].siz=t[rt].sum=t[rt].v=0; scanf("%*d"); while (scanf("%d",&opt)!=EOF&&opt!=3) { if (opt==1) { scanf("%d%d%d",&now.d[0],&now.d[1],&now.v); now.d[0]^=ans; now.d[1]^=ans; now.v^=ans; ins(rt,1); } else{ int x1,y1,x2,y2; scanf("%d%d%d%d",&x1,&y1,&x2,&y2); x1^=ans;y1^=ans;x2^=ans;y2^=ans; printf("%d\n",ans=query(rt,x1,y1,x2,y2)); } } }
BZOJ 4066 简单题 ——KD-Tree套替罪羊树的更多相关文章
- bzoj 4066: 简单题 K-D树
题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=4066 题解 我们把每次的修改操作都当作二维平面上多了一个权值点 对于每组询问可以看做求一 ...
- bzoj 4066: 简单题 kd-tree
4066: 简单题 Time Limit: 50 Sec Memory Limit: 20 MBSubmit: 234 Solved: 82[Submit][Status][Discuss] De ...
- bzoj 4066 简单题——KDtree(带重构)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4066 带部分重构的KDtree.就是那个替罪羊树思想的. 写了对拍,调了半天,发现忘了 re ...
- BZOJ4066:简单题(K-D Tree)
Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要维护两种操作: 命令 参数限制 内容 1 x y A 1<=x,y<=N,A是正整数 ...
- P4148 简单题 k-d tree
思路:\(k-d\ tree\) 提交:2次 错因:整棵树重构时的严重错误:没有维护父子关系(之前写的是假重构所以没有维护父子关系) 题解: 遇到一个新的点就插进去,如果之前出现过就把权值加上. 代码 ...
- BZOJ 4066 简单题(KD树)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4066 [题目大意] 要求维护矩阵内格子加点和矩阵查询 [题解] 往KD树上加权值点,支 ...
- bzoj 4066 & bzoj 2683 简单题 —— K-D树(含重构)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4066 https://www.lydsy.com/JudgeOnline/problem.p ...
- bzoj 4066: 简单题
#include<cstdio> #include<iostream> #include<cstdlib> #include<algorithm> #d ...
- 【CJOJ2433】陌上花开 树状数组套替罪羊树
[CJOJ2433]陌上花开 树状数组套替罪羊树 蛤?bzoj?没权限QAQ 蛤?CDQ?看了好久没看懂QwQ 好吧我会拿cdq再写一遍的 为啥我感觉这东西比cdq好写 只好拿树状数组套替罪羊树水水了 ...
随机推荐
- RN8209校正软件开发心得(1)
最近领导突然让我做软件了,头大啊.以前也没怎么自己独立做过软件,这次来的突然啊,面对这么大的任务量自己只能加把劲了,还等着领导给涨工资呢,哈哈... 作为编程的小白,要自己做一款上位机的软件实属不易啊 ...
- saltstack 把数据返回到mysql服务器
环境:http://www.cnblogs.com/zzzhfo/p/5790918.html master端需要安装MySQL-python和mysql-server mysql-server用于存 ...
- JQuery动画队列问题
在上网的时候经常会发现一些网站上发现一些bug,如导航菜单的动画队列问题(在同一个元素上执行多个动画,那么对于这个动画来说,后面的动画 会被放到动画队列中,等前面的动画执行完成了才会执行) 要解决问题 ...
- 耿丹CS16-2班助教总结
Deadline: 2016-1-7 11:59pm 开篇有言 --又是一年末,不似风光,却添风霜,顶霾前进,踽踽独行,可乎? 助教那些事儿 助教这份工作是之前就担任过的,很羞愧,当时才担任了几天就撒 ...
- c++中的继承与初始化
1.在c++中构造函数.析构函数.=运算符.友元无法继承 2.const 成员.引用成员.类的对象成员没有默认构造函数时,需在类的构造函数初始化列表中对其进行初始化 3.基类无默认构造函数,派生类需在 ...
- angularJS实践过程中出现的问题总结
同名服务 在一次项目里,之前是同事写的.我有一次在异步获取服务器上的数据时,习惯把api地址写在一个服务Store里,但是程序总是返回Store.api.get()里的get is undefined ...
- Tsinsen A1486. 树(王康宁)
Description 一棵树,问至少有 \(k\) 个黑点的路径最大异或和. Sol 点分治. 用点分治找重心控制树高就不说了,主要是对答案的统计的地方. 将所有路径按点的个数排序. 可以发现当左端 ...
- setprecision **fixed
#include <iostream> #include <iomanip> using namespace std; int main( void ) { const dou ...
- Gulp真实项目用例
包括了less预编译,css压缩,html文件include引入,js混淆压缩,本地开发热刷新服务器,html压缩,版本号添加 github地址: gulpfile.js var gulp = req ...
- foxmail邮箱,签名中如何添加当前日期
菜单--工具--模板管理 当前HTML模板中光标定位在签名之前,然后进行操作:插入宏--当前日期,适当调整位置即可 最下方为新邮件选择HTML模板 新建一封邮件试试吧