传送门

题意:

先有两种操作,插入和查询,插入操作则插入一个点\((x,y,z)\),查询操作给出两个点\((x_1,y_1,z_1),(x_2,y_2,z_2)\),回答满足\(x_1\leq x\leq x_2,y_1\leq y\leq y_2,z_1\leq z\leq z_2\)的\((x,y,z)\)的个数为多少。

思路:

就是带修改的四维偏序问题。

首先我们可以将每个点看作三维空间中的一个点,那么每次询问就相当于询问立方体中的点。

我们将询问拆成\(8\)个询问,那么每次解决的就是一个前缀和问题,也就是满足\(x\leq x_0,y\leq y_0,z\leq z_0\)的点的个数。

那么就对一维排序,之后\(cdq\)套\(cdq\)再套个树状数组就好啦。

注意我们现在只有左边区间的修改操作才会对右边区间的询问操作有影响~

注意一下空间,要开大点。

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 50005; int T, q; struct node{
int x, y, z, op, id, part;
}a[N * 10], b[N * 10], d[N * 10]; int hs[N << 2]; bool isq[N];
int ans[N]; int c[N << 2];
int lowbit(int x) {return x & (-x);} void update(int x, int v) {
for(; x < N << 2; x += lowbit(x)) c[x] += v;
} int query(int x) {
int ans = 0;
for(; x; x -= lowbit(x)) ans += c[x];
return ans;
} void cdq2(int l, int r) {
if(l == r) return ;
int mid = (l + r) >> 1;
cdq2(l, mid); cdq2(mid + 1, r);
int t1 = l, t2 = mid + 1;
for(int i = l; i <= r; i++) {
if(t2 > r || (t1 <= mid && b[t1].y <= b[t2].y)) {
if(b[t1].part == 0 && b[t1].op == 0) {
update(b[t1].z, 1);
}
d[i] = b[t1++];
} else {
if(b[t2].part && b[t2].op != 0) {
ans[b[t2].id] += b[t2].op * query(b[t2].z);
}
d[i] = b[t2++];
}
}
for(int i = l; i <= mid; i++) {
if(b[i].part == 0 && b[i].op == 0) update(b[i].z, -1);
}
for(int i = l; i <= r; i++) b[i] = d[i];
} void cdq(int l, int r) {
if(l == r) return ;
int mid = (l + r) >> 1;
cdq(l, mid); cdq(mid + 1, r);
int t1 = l, t2 = mid + 1;
for(int i = l; i <= r; i++) {
if(t2 > r || (t1 <= mid && a[t1].x <= a[t2].x)) {
b[i] = a[t1++];
b[i].part = 0;
} else {
b[i] = a[t2++];
b[i].part = 1;
}
}
for(int i = l; i <= r; i++) a[i] = b[i];
cdq2(l, r);
} int main() {
// freopen("input.in", "r", stdin);
ios::sync_with_stdio(false); cin.tie(0);
cin >> T;
while(T--) {
cin >> q;
for(int i = 1; i <= q; i++) ans[i] = 0, isq[i] = false;
int cnt = 0; hs[0] = 0;
for(int i = 1; i <= q; i++) {
int op; cin >> op;
if(op == 1) {
int x, y, z; cin >> x >> y >> z;
a[++cnt] = {x, y, z, 0, i, -1};
hs[++hs[0]] = z;
} else {
isq[i] = true;
int x1, y1, z1, x2, y2, z2;
cin >> x1 >> y1 >> z1 >> x2 >> y2 >> z2;
--x1, --y1, --z1;
a[++cnt] = {x1, y1, z1, -1, i, -1};
a[++cnt] = {x1, y2, z1, 1, i, -1};
a[++cnt] = {x2, y2, z1, -1, i, -1};
a[++cnt] = {x2, y1, z1, 1, i, -1};
a[++cnt] = {x1, y1, z2, 1, i, -1};
a[++cnt] = {x1, y2, z2, -1, i, -1};
a[++cnt] = {x2, y2, z2, 1, i, -1};
a[++cnt] = {x2, y1, z2, -1, i, -1};
hs[++hs[0]] = z1, hs[++hs[0]] = z2;
}
}
sort(hs + 1, hs + hs[0] + 1);
hs[0] = unique(hs + 1, hs + hs[0] + 1) - hs - 1;
for(int i = 1; i <= cnt; i++) a[i].z = lower_bound(hs + 1, hs + hs[0] + 1, a[i].z) - hs;
cdq(1, cnt);
for(int i = 1; i <= q; i++) {
if(isq[i]) cout << ans[i] << '\n';
}
}
return 0;
}

HDU5126 stars(cdq分治)的更多相关文章

  1. HDU5126 stars(CDQ分治)

    传送门 大意: 向三维空间中加点,询问一个三维区间中点的个数. 解题思路: 带修改CDQ,将修改和询问一起插入CDQ分治询问. (询问可以由8个前缀和加减操作实现) 其中第一层CDQ维护x有序. 第二 ...

  2. hdu 5126 stars cdq分治套cdq分治+树状数组

    题目链接 给n个操作, 第一种是在x, y, z这个点+1. 第二种询问(x1, y1, z1). (x2, y2, z2)之间的总值. 用一次cdq分治可以将三维变两维, 两次的话就变成一维了, 然 ...

  3. HDU - 5126 stars (CDQ分治)

    题目链接 题目大意:一共有Q(1<=Q<=50000)组操作,操作分为两种: 1.在x,y,z处添加一颗星星 2.询问以(x1,y1,z1)与(x2,y2,z2)为左上和右下顶点的矩形之间 ...

  4. HDU5126 stars【CDQ分治】*

    HDU5126 stars Problem Description John loves to see the sky. A day has Q times. Each time John will ...

  5. [学习笔记]CDQ分治和整体二分

    序言 \(CDQ\) 分治和整体二分都是基于分治的思想,把复杂的问题拆分成许多可以简单求的解子问题.但是这两种算法必须离线处理,不能解决一些强制在线的题目.不过如果题目允许离线的话,这两种算法能把在线 ...

  6. CDQ分治笔记

    以前一直不会CDQ……然后经常听到dalao们说“这题直接CDQ啊”“CDQ不就秒了吗”的时候我只能瑟瑟发抖QAQ CDQ分治 其实CDQ分治就是二分分治,每次将$[l,r]$的问题划分为$[l,mi ...

  7. CDQ分治--用时间降维的美丽算法

    CDQ分治–用时间降维的美丽算法 CDQ分治,网上的阐述很多,太专业性的文字我就不赘述,这里指谈谈自己的感受 还是%一下CDQ大神的论文 CDQ分治的主要想法就是降维(比如三维问题降维到二维问题),并 ...

  8. CDQ分治的嵌套

    CDQ的嵌套 上一篇博客介绍了一下CDQ的入门思想.这里再介绍一下它的进阶,CDQ套CDQ.其实如果对入门思想掌握的透彻,嵌套也是很容易掌握的,思想是一样的. 什么是嵌套 简单地说,有的问题,如果用一 ...

  9. CDQ分治&整体二分学习个人小结

    目录 小结 CDQ分治 二维LIS 第一道裸题 bzoj1176 Mokia bzoj3262 陌上花开 bzoj 1790 矩形藏宝地 hdu5126四维偏序 P3157 [CQOI2011]动态逆 ...

  10. 技巧专题3(cdq分治、整体二分等)

    cdq分治与整体二分 cdq来源于2008年国家集训队作业陈丹琦(雅礼巨佬),用一个log的代价完成从静态到动态(很多时候是减少时间那一维的). 对于一个时间段[L, R],我们取mid = (L + ...

随机推荐

  1. MySQL实战45讲学习笔记:第九讲

    一.今日内容概要 今天的正文开始前,我要特意感谢一下评论区几位留下高质量留言的同学.用户名是 @某.人 的同学,对文章的知识点做了梳理,然后提了关于事务可见性的问题,就是先启动但是后提交的事务,对数据 ...

  2. java --后缀符号

    public class Sample { public static void main(String[] args) { , num2 = ; num1--; System.out.println ...

  3. 关于DTO的定义问题。以及C#语言扩展的思考。

    数据传输对象 是我们经常用到的一个东西.有时候我们称之为的ViewModel也属于其中之一. 但是以往,我们总是 复制 实体类型的一些字段 然后单独创建这些对象.然后我们使用对象映射工具 进行值层面的 ...

  4. Python 遍历目录下的子目录和文件

    import os A: 遍历目录下的子目录和文件 for root,dirs ,files in os.walk(path) root:要访问的路径名 dirs:遍历目录下的子目录 files:遍历 ...

  5. SWIG 3 中文手册——5. SWIG 基础知识

    目录 5 SWIG 基础知识 5.1 运行 SWIG 5.1.1 输入格式 5.1.2 SWIG 输出 5.1.3 注释 5.1.4 C 预处理器 5.1.5 SWIG 指令 5.1.6 解析限制 5 ...

  6. 在linux上安装taiga

    # taiga 安装配置 1.简介 本文档介绍了如何部署完整的Taiga服务(每个模块都是Taiga平台的一部分). Taiga平台由三个主要组件组成,每个组件在编译时和运行时都有自己的依赖关系: t ...

  7. VSCode批量替换使用注意问题

    VSCode批量替换功能很强大,需要注意两点 1.不要搜到文件个数超过到10000时替换,这时替换过程中可能会出错崩溃(也可能是服务器上内存较小导致) 2.不要在搜索中反复替换可能会导致数据错乱 比如 ...

  8. wordcount实例

    scala的wordcount实例 package com.wondersgroup.myscala import scala.actors.{Actor, Future} import scala. ...

  9. zbar android sdk在CentOS 7下的编译和使用

    环境:CentOS 7+NDK 20.0.5594570+libiconv-1.14 下载 下载libiconv-1.14版本,地址: https://ftp.gnu.org/pub/gnu/libi ...

  10. 【02】Kubernets:使用 kubeadm 部署 K8S 集群

    写在前面的话 通过上一节,知道了 K8S 有 Master / Node 组成,但是具体怎么个组成法,就是这一节具体谈的内容.概念性的东西我们会尽量以实验的形式将其复现. 部署 K8S 集群 互联网常 ...