浅谈\(K-D\) \(Tree\):https://www.cnblogs.com/AKMer/p/10387266.html

题目传送门:https://lydsy.com/JudgeOnline/problem.php?id=4066

裸的强制在线插入点,像替罪羊树那样重建不平衡的子树即可。在回收要重建的子树的节点的时候记得把结点信息初始化掉。

时间复杂度:\(O(n\sqrt{n})\)

空间复杂度:\(O(n)\)

代码如下:

  1. #include <cstdio>
  2. #include <algorithm>
  3. using namespace std;
  4. const double alpha=0.75;
  5. const int maxn=2e5+5,inf=2e9;
  6. bool need_rebuild;
  7. int n,lstans,pps,x,y,A,x1,x2,y1,y2;
  8. int read() {
  9. int x=0,f=1;char ch=getchar();
  10. for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
  11. for(;ch>='0'&&ch<='9';ch=getchar())x=x*10+ch-'0';
  12. return x*f;
  13. }
  14. struct kd_tree {
  15. int id[maxn];
  16. int tot,root,cnt;
  17. struct point {
  18. int c[2],mn[2],mx[2];
  19. int val,sum,siz,ls,rs;
  20. bool operator<(const point &a)const {
  21. return c[pps]<a.c[pps];
  22. }
  23. }p[maxn],node[maxn];
  24. void prepare() {
  25. p[0].mn[0]=p[0].mn[1]=inf;
  26. p[0].mx[0]=p[0].mx[1]=-inf;
  27. }
  28. void update(int u) {
  29. int ls=p[u].ls,rs=p[u].rs;
  30. p[u].siz=p[ls].siz+1+p[rs].siz;
  31. p[u].sum=p[ls].sum+p[u].val+p[rs].sum;
  32. for(int i=0;i<2;i++) {
  33. int mn=min(p[ls].mn[i],p[rs].mn[i]);
  34. p[u].mn[i]=min(p[u].c[i],mn);
  35. int mx=max(p[ls].mx[i],p[rs].mx[i]);
  36. p[u].mx[i]=max(p[u].c[i],mx);
  37. }
  38. }
  39. void ins(int &u,int d) {
  40. if(!u) {
  41. u=++tot;need_rebuild=1;
  42. p[u].mn[0]=p[u].mx[0]=p[u].c[0]=x;
  43. p[u].mn[1]=p[u].mx[1]=p[u].c[1]=y;
  44. p[u].val=p[u].sum=A,p[u].siz=1;return;
  45. }
  46. if(p[u].c[0]==x&&p[u].c[1]==y) {
  47. p[u].val+=A,p[u].sum+=A;return;
  48. }
  49. int tmp=d?y:x;
  50. if(tmp<p[u].c[d])ins(p[u].ls,d^1);
  51. else ins(p[u].rs,d^1);
  52. update(u);
  53. }
  54. void recycle(int u) {
  55. if(!u)return;
  56. int ls=p[u].ls,rs=p[u].rs;
  57. p[u].siz=1,p[u].ls=p[u].rs=p[u].sum=0;
  58. id[++cnt]=u,node[cnt]=p[u];
  59. recycle(ls),recycle(rs);
  60. }
  61. int rebuild(int l,int r,int d) {
  62. int mid=(l+r)>>1,u=id[mid];pps=d;
  63. nth_element(node+l,node+mid,node+r+1);
  64. p[u]=node[mid];
  65. if(l<mid)p[u].ls=rebuild(l,mid-1,d^1);
  66. if(r>mid)p[u].rs=rebuild(mid+1,r,d^1);
  67. update(u);return u;
  68. }
  69. void check(int &u,int d) {
  70. int siz1=p[p[u].ls].siz,siz2=p[p[u].rs].siz;
  71. if(max(siz1,siz2)>1.0*p[u].siz*alpha) {
  72. recycle(u),u=rebuild(1,cnt,d),cnt=0;return;
  73. }
  74. if(p[u].c[0]==x&&p[u].c[1]==y)return;
  75. int tmp=d?y:x;
  76. if(tmp<p[u].c[d])check(p[u].ls,d^1);
  77. else check(p[u].rs,d^1);
  78. }
  79. void query(int u) {
  80. if(!u)return;
  81. if(x2<p[u].mn[0]||x1>p[u].mx[0])return;
  82. if(y2<p[u].mn[1]||y1>p[u].mx[1])return;
  83. bool bo1=(x1<=p[u].mn[0]&&p[u].mx[0]<=x2);
  84. bool bo2=(y1<=p[u].mn[1]&&p[u].mx[1]<=y2);
  85. if(bo1&&bo2) {lstans+=p[u].sum;return;}
  86. bo1=(x1<=p[u].c[0]&&p[u].c[0]<=x2);
  87. bo2=(y1<=p[u].c[1]&&p[u].c[1]<=y2);
  88. if(bo1&&bo2)lstans+=p[u].val;
  89. if(p[u].ls)query(p[u].ls);
  90. if(p[u].rs)query(p[u].rs);
  91. }
  92. }T;
  93. int main() {
  94. n=read();T.prepare();
  95. while(1) {
  96. int opt=read();
  97. if(opt==1) {
  98. x=read()^lstans,y=read()^lstans,A=read()^lstans;
  99. T.ins(T.root,0);if(need_rebuild)T.check(T.root,0);
  100. }
  101. if(opt==2) {
  102. x1=read()^lstans,y1=read()^lstans;
  103. x2=read()^lstans,y2=read()^lstans;
  104. lstans=0,T.query(T.root),printf("%d\n",lstans);
  105. }
  106. if(opt==3)break;
  107. }
  108. return 0;
  109. }

BZOJ4066:简单题的更多相关文章

  1. [BZOJ2683][BZOJ4066]简单题

    [BZOJ2683][BZOJ4066]简单题 试题描述 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要维护两种操作: 命令 参数限制 内容 1 x y A 1<=x ...

  2. bzoj4066: 简单题 K-Dtree

    bzoj4066: 简单题 链接 bzoj 思路 强制在线.k-dtree. 卡常啊.空间开1e6就T了. 代码 #include <bits/stdc++.h> #define my_m ...

  3. Bzoj4066 简单题

    Time Limit: 50 Sec  Memory Limit: 20 MBSubmit: 2185  Solved: 581 Description 你有一个N*N的棋盘,每个格子内有一个整数,初 ...

  4. BZOJ4066 简单题(KD-Tree)

    板子题. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> # ...

  5. 【kd-tree】bzoj4066 简单题

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

  6. BZOJ4066:简单题(K-D Tree)

    Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要维护两种操作:   命令 参数限制 内容 1 x y A 1<=x,y<=N,A是正整数 ...

  7. 【BZOJ4066】简单题(KD-Tree)

    [BZOJ4066]简单题(KD-Tree) 题面 BZOJ 题解 如果这题不卡空间,并且不强制在线的话 显然可以用\(CDQ\)分治做 但是它又卡空间又强制在线,于是我们欢快的来用\(KD-Tree ...

  8. 【BZOJ4066】简单题 KDtree

    [BZOJ4066]简单题 Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要维护两种操作: 命令 参数限制 内容 1 x y A 1<=x,y& ...

  9. [bzoj4066/2683]简单题_KD-Tree

    简单题 bzoj-4066 题目大意:n*n的棋盘,开始为均为0,支持:单点加权值,查询矩阵权值和,强制在线. 注释:$1\le n\le 5\cdot 10^5$,$1\le m \le 2\cdo ...

  10. BZOJ 2683: 简单题

    2683: 简单题 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 913  Solved: 379[Submit][Status][Discuss] ...

随机推荐

  1. 定制AIX操作系统的shell环境

    操作系统与外部最主要的接口就叫做shell.shell是操作系统最外面的一层.shell管理你与操作系统之间的交互:等待你输入,向操作系统解释你的输入,并且处理各种各样的操作系统的输出结果. shel ...

  2. 跨平台移动开发 App-Framework DEMO 演示

    穿越到2015 回到->MarkFan的程序员客栈 App-Framework   DEMO 演示 点击APK包下载 点击Demo代码下载 官方网站 :http://app-framework- ...

  3. iptables DNAT、SNAT和MASQUERATE

    MASQUERADE 地址伪装,和SNAT功能一样,只不过SNAT使用固定IP地址,MASQUERADE使用网卡上的地址. SNAT配置: iptables -t nat -A POSTROUTING ...

  4. js学习笔记2(5章操作方法)

    5.2.5操作 concat();将slice(); 5.2.7位置操作的方法 其他的不赘述 5.5 函数 1.函数其实是对象,每一个函数都是function对象的实例,与其他引用类型一样,都具有属性 ...

  5. log4j2.xml配置文件

    <?xml version="1.0" encoding="UTF-8"?> <!--日志级别以及优先级排序: OFF > FATAL ...

  6. 考勤助手——基于CS三层结构的子系统设计

    因为小组比较倾向于cs分层结构的风格,所以基于对考勤助手最初的体系架构的设计进行了子系统的分层设计,如下图: 1.教务老师安排课程子系统 2.教务老师查询相关信息的子系统 3.任课教师管理考勤子系统 ...

  7. 如何用wamp配置多域名虚拟目录

    一.前言 自从重装了最新版wamp64后就不可用了,下面来介绍我的解决方法,两者均可尝试,差别并不大! 二.配置虚拟主机 1.首先打开apache的配置文件httpd.conf (路径\wamp64\ ...

  8. Codeforces Round #390 (Div. 2) A B C D

    这是一场比较难的div2 ... 比赛的时候只出了AB A很有意思 给出n个数 要求随意的把相邻的数合并成任意多数 最后没有为0的数 输出合并区间个数与区间 可以想到0可以合到任何数上并不改变该数的性 ...

  9. Yum 命令语法

    一.Yum 命令格式: yum <options> <command><package...> 二.参数说明 1.options: 1)-y:如果在工作过程中如要使 ...

  10. nova instance启动中的同步与异步

    instance create:nova/api/servers.create -- self.compute_api.create -- self.compute_task_api.build_in ...