Description

给你一个 \(W~\times~W\) 的矩阵,每个点有权值,每次进行单点修改或者求某子矩阵内权值和,允许离线

Input

第一行是两个数字 \(0\) 和矩阵大小 \(W\)

下面每行可能会出现如下参数

\(1,x,y,A\) 单点修改格子 \(x,y\) 为 \(A\)

\(2,x_1,y_1,x_2,y_2\) 查询给定矩阵的权值和

\(3\) 结束查询与修改

Output

对每个查询给出一行作为答案

Hint

\(1~\leq~W~\leq~2000000\)

修改不超过 \(1.6e5\) 个

查询不超过 \(1e4\) 个

保证答案在整形范围内

Solution

这不傻逼题,直接树状数组套treap完事了

我们考虑离线乱搞一下

将查询改为每次查询二维前缀和容斥的形式进行四次单点查询。

我们考虑对 \(x,y\) 的前缀和查询:

我们只需要考虑修改时间在该次查询之前,且 \(x_0~\leq~x~\land~y_0~\leq~y\) 的修改操作 \((x_0,y_0)\)。

我们发现这是一个标准的cdq分治模型:

第一维为时间序,第二维为 \(x\) 坐标,第三维为 \(y\) 坐标。

时间序默认有序,每次考虑前半部分的 \(x_0~\leq~x\) 的点中 \(y_0~\leq~y\) 的点对答案的贡献,用树状数组来统计这部分答案

时间复杂度 \(O(n~\log^2 n)\),空间复杂度 \(O(n~\log n)\)

Code

#include <cstdio>
#include <vector>
#include <iostream>
#ifdef ONLINE_JUDGE
#define freopen(a, b, c)
#endif typedef long long int ll; namespace IPT {
const int L = 1000000;
char buf[L], *front=buf, *end=buf;
char GetChar() {
if (front == end) {
end = buf + fread(front = buf, 1, L, stdin);
if (front == end) return -1;
}
return *(front++);
}
} template <typename T>
inline void qr(T &x) {
char ch = IPT::GetChar(), lst = ' ';
while ((ch > '9') || (ch < '0')) lst = ch, ch=IPT::GetChar();
while ((ch >= '0') && (ch <= '9')) x = (x << 1) + (x << 3) + (ch ^ 48), ch = IPT::GetChar();
if (lst == '-') x = -x;
} namespace OPT {
char buf[120];
} template <typename T>
inline void qw(T x, const char aft, const bool pt) {
if (x < 0) {x = -x, putchar('-');}
int top=0;
do {OPT::buf[++top] = static_cast<char>(x % 10 + '0');} while (x /= 10);
while (top) putchar(OPT::buf[top--]);
if (pt) putchar(aft);
} const int maxn = 2000010; struct OP {
int x, y, id, v; inline void print() {
std::cerr << x << ' ' << y << ' ' << id << ' ' << v << std::endl;
}
};
std::vector<OP> Q; int n, cnt;
int ans[maxn], tree[maxn]; int query(int);
int lowbit(int);
void cdq(int, int);
void update(int, int); int main() {
freopen("1.in", "r", stdin);
int a, b, c, d;
qr(a); qr(n); a = 0; qr(a);
while (a != 3) {
if (a == 1) {
a = b = c = 0; qr(a); qr(b); qr(c);
Q.push_back({a, b, 0, c});
} else {
a = b = c = d = 0; qr(a); qr(b); qr(c); qr(d);
Q.push_back({c, d, ++cnt, 1});
Q.push_back({a - 1, b - 1, cnt, 1});
Q.push_back({c, b - 1, cnt, -1});
Q.push_back({a - 1, d, cnt, -1});
}
a = 0; qr(a);
}
cdq(0, Q.size() - 1);
for (int i = 1; i <= cnt; ++i) qw(ans[i], '\n', true);
return 0;
} void cdq(int l, int r) {
if (l == r) return;
int mid = (l + r) >> 1;
cdq(l, mid); cdq(mid + 1, r);
std::vector<OP>temp;
int pre = l;
for (int i = mid + 1; i <= r; ++i) {
while ((pre <= mid) && (Q[pre].x <= Q[i].x)) {
if (Q[pre].id == 0) update(Q[pre].y, Q[pre].v);
temp.push_back(Q[pre++]);
}
ans[Q[i].id] += Q[i].v * query(Q[i].y);
temp.push_back(Q[i]);
}
for (int i = l; i < pre; ++i) if (Q[i].id == 0) update(Q[i].y, -Q[i].v);
while (pre <= mid) temp.push_back(Q[pre++]);
for (int i = l; i <= r; ++i) Q[i] = temp[i - l];
} inline int lowbit(int x) {return x & -x;} void update(int x, int v) {
while (x <= n) {
tree[x] += v; x += lowbit(x);
}
} int query(int x) {
int _ret = 0;
while (x) {
_ret += tree[x];
x -= lowbit(x);
}
return _ret;
}

【cdq分治】【P4390】[BOI2007]Mokia 摩基亚的更多相关文章

  1. 洛谷 P4390 [BOI2007]Mokia 摩基亚 解题报告

    P4390 [BOI2007]Mokia 摩基亚 题目描述 摩尔瓦多的移动电话公司摩基亚(\(Mokia\))设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如"用户 ...

  2. P4390 [BOI2007]Mokia 摩基亚 (CDQ解决三维偏序问题)

    题目描述 摩尔瓦多的移动电话公司摩基亚(Mokia)设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如"用户C的位置在哪?"的问题,精确到毫米.但其真正高科 ...

  3. Luogu P4390 [BOI2007]Mokia 摩基亚 | CDQ分治

    题目链接 $CDQ$分治. 考虑此时在区间$[l,r]$中,要计算$[l,mid]$中的操作对$[mid+1,r]$中的询问的影响. 计算时,排序加上树状数组即可. 然后再递归处理$[l,mid]$和 ...

  4. [洛谷P4390][BOI2007]Mokia 摩基亚

    题目大意: 维护一个W*W的矩阵,每次操作可以增加某格子的权值,或询问某子矩阵的总权值. 题解:CDQ分治,把询问拆成四个小矩形 卡点:无 C++ Code: #include <cstdio& ...

  5. P4390 [BOI2007]Mokia 摩基亚

    传送门 对于一个询问 $(xa,ya),(xb,yb)$,拆成 $4$ 个询问并容斥一下 具体就是把询问变成求小于等于 $xb,yb$ 的点数,减去小于等于 $xa-1,yb$ 和小于等于 $xb,y ...

  6. P4390 [BOI2007]Mokia 摩基亚(cdq分治)

    一样是cdq的板子 照着园丁的烦恼就好了 代码 #include <cstdio> #include <cstring> #include <algorithm> ...

  7. 【BZOJ1176】[BOI2007]Mokia 摩基亚

    [BZOJ1176][BOI2007]Mokia 摩基亚 题面 bzoj 洛谷 题解 显然的\(CDQ\)\(/\)树套树题 然而根本不想写树套树,那就用\(CDQ\)吧... 考虑到点\((x1,y ...

  8. cogs1752[boi2007]mokia 摩基亚 (cdq分治)

    [题目描述] 摩尔瓦多的移动电话公司摩基亚(Mokia)设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如“用户C的位置在哪?”的问题,精确到毫米.但其真正高科技之处在于,它能 ...

  9. [BOI2007]Mokia 摩基亚

    Description: 摩尔瓦多的移动电话公司摩基亚(Mokia)设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如"用户C的位置在哪?"的问题,精确到毫 ...

随机推荐

  1. spring boot+mybatis+swagger搭建

    环境概述 使用的开发工具:idea 2018 3.4 环境:jdk1.8 数据库:MariaDB (10.2.21) 包管理:Maven 3.5 Web容器:Tomcat 8.0 开发机系统:Wind ...

  2. JS以及CSS对页面的阻塞

    一.JS阻塞 所有的浏览器在下载JS文件的时候,会阻塞页面上的其他活动,包括其他资源的下载以及页面内容的呈现等等,只有当JS下载.解析.执行完,才会进行后面的 操作.在现代的浏览器中CSS资源和图片i ...

  3. 第十三次作业psp

    psp 进度条 代码累积折线图 博文累积折线图 psp饼状图

  4. Thunder团队--Beta发布用户使用报告

    Thunder爱阅app Beta 发布用户使用报告 用户数量:14人 以下为用户评论:(注:为了保护用户的姓名权,以下用户名以昵称形式给出.) 序号 昵称 个人信息 获得软件途径 使用次数 用户评论 ...

  5. 互评Beta版本-SkyHunter

    基于NABCD评论作品,及改进建议 1.根据(不限于)NABCD评论作品的选题;   N(Need,需求):飞机大战题材的游戏对80,90后的人来说算是童年的记忆,可以在闲暇之余打开电脑玩一会儿.但是 ...

  6. 项目冲刺Beta第二篇博客

    Beta版本冲刺计划安排 1.当天站立式会议照片: 2.工作分工: 团队成员 分工 张洪滨060  排行榜界面美化 陈敬轩059  注册成功界面美化 黄兴067  登录界面美化 林国梽068  答题界 ...

  7. week4d:个人博客作业

    7,程序结果的显示 1,界面 2,选第一选项. 3,输入3个数后. 4,选择第一个. 5,输入第4个数字. 6,再次进行一轮游戏. 7,选择是否要看历史记录. 8,进入下一轮游戏. 9,开始第二轮数字 ...

  8. week4c:个人博客作业

    6.具体程序: #include<stdio.h>#include<stdlib.h>#include<math.h>void Udecide_n();int De ...

  9. js 刷新当前页面会弹出提示框怎样将这个提示框去掉

    //禁止刷新提示window.onbeforeunload = function() { var n = window.event.screenX - window.screenLeft; var b ...

  10. 安装mysql后遇到的一些问题

    我们安装好了mysql(cnetos7上是安装mariadb)后,出现如下图所示的问题,我们可以用netstat -lntup查看以下服务器的端口,mysql的端口一般默认为 3306,查看服务是否启 ...