【COGS1752】 BOI2007—摩基亚Mokia
http://cogs.pro/cogs/problem/problem.php?pid=1752 (题目链接)
题意
给出$n*n$的棋盘,单点修改,矩阵查询。
Solution
离线以后CDQ分治。每一层按照$Y$排序,然后询问用前缀和拆成$4$个,树状数组维护一下就可以了。
细节
?
代码
// cogs1752
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define inf (1ll<<30)
#define Pi acos(-1.0)
#define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout)
using namespace std; const int maxn=200010,maxd=2000010;
int c[maxd],ans[maxn],n,m;
struct data {int x,y,k,id,op;}q[maxn<<2],nq[maxn<<2]; int lowbit(int x) {
return x&-x;
}
void add(int x,int val) {
for (int i=x;i<=n;i+=lowbit(i)) c[i]+=val;
}
int query(int x) {
int res=0;
for (int i=x;i;i-=lowbit(i)) res+=c[i];
return res;
}
void solve(int l,int r) {
if (l==r) return;
int mid=(l+r)>>1,l1=l,l2=mid+1;
for (int i=l;i<=r;i++) q[i].id<=mid ? nq[l1++]=q[i] : nq[l2++]=q[i];
for (int i=l;i<=r;i++) q[i]=nq[i];
solve(l,mid);solve(mid+1,r);
for (int i=l,j=mid+1,k=l;i<=mid || j<=r;) {
if (j>r || (i<=mid && q[i].y<=q[j].y)) {
if (q[i].k>0) add(q[i].x,q[i].k);
nq[k++]=q[i++];
}
else {
if (q[j].k<0) ans[-q[j].k]+=q[j].op*query(q[j].x);
nq[k++]=q[j++];
}
}
for (int i=l;i<=mid;i++) if (q[i].k>0) add(q[i].x,-q[i].k);
for (int i=l;i<=r;i++) q[i]=nq[i];
}
int main() {
free("mokia");
int T,tot=0;
while (scanf("%d",&T)!=EOF) {
if (T==0) scanf("%d",&n);
if (T==1) {
int x,y,k;
scanf("%d%d%d",&x,&y,&k);
m++,q[m]=(data){x,y,k,m,0};
}
if (T==2) {
int x1,y1,x2,y2;tot++;
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
m++,q[m]=(data){x1-1,y1-1,-tot,m,1};
m++,q[m]=(data){x1-1,y2,-tot,m,-1};
m++,q[m]=(data){x2,y1-1,-tot,m,-1};
m++,q[m]=(data){x2,y2,-tot,m,1};
}
if (T==3) break;
}
solve(1,m);
for (int i=1;i<=tot;i++) printf("%d\n",ans[i]);
return 0;
}
【COGS1752】 BOI2007—摩基亚Mokia的更多相关文章
- COGS1752. [BOI2007]摩基亚Mokia
		1752. [BOI2007]摩基亚Mokia ★★☆ 输入文件:mokia.in 输出文件:mokia.out 简单对比时间限制:5 s 内存限制:128 MB [题目描述] 摩尔瓦 ... 
- COGS1752 [BOI2007]摩基亚Mokia(CDQ分治 + 二维前缀和 + 线段树)
		题目这么说的: 摩尔瓦多的移动电话公司摩基亚(Mokia)设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如“用户C的位置在哪?”的问题,精确到毫米.但其真正高科技之处在于,它 ... 
- COGS1752. [BOI2007]摩基亚Mokia(CDQ,树状数组)
		题目描述 摩尔瓦多的移动电话公司摩基亚(Mokia)设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如“用户C的位置在哪?”的问题,精确到毫米.但其真正高科技之处在于,它能够回 ... 
- COGS1752. [BOI2007]摩基亚Mokia CDQ
		CDQ的板子题 #include<cstdio> #include<cstring> #include<iostream> #include<algorith ... 
- COJS 1752. [BOI2007]摩基亚Mokia
		1752. [BOI2007]摩基亚Mokia ★★★ 输入文件:mokia.in 输出文件:mokia.out 简单对比时间限制:5 s 内存限制:128 MB [题目描述] 摩尔瓦 ... 
- 分治(CDQ):[BOI2007]摩基亚Mokia
		[题目描述] 摩尔瓦多的移动电话公司摩基亚(Mokia)设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如“用户C的位置在哪?”的问题,精确到毫米.但其真正高科技之处在于,它能 ... 
- Bzoj1176:Mokia&Cogs1752:[BOI2007]摩基亚Mokia
		题目 Cogs 没有Bzoj的权限号 Sol 离线,\(CDQ\)分治,把询问拆成\(4\)个,变成每次求二位前缀和 那么只要一个修改操作(关键字为时间,\(x\),\(y\))都在这个询问前,就可以 ... 
- [COGS 1752] 摩基亚Mokia
		照例先上题面 1752. [BOI2007]摩基亚Mokia 输入文件:mokia.in 输出文件:mokia.out 时间限制:1.5 s 内存限制:128 MB [题目描述] 摩尔瓦多的移 ... 
- [BOI2007]摩基亚
		题目:洛谷P4390.BZOJ1176. 题目大意: 给你一个\(W\times W\)的矩阵,初始每个数都为\(S\).现在有若干操作: 1. 给某个格子加上一个值:2. 询问某个子矩阵的值的和:3 ... 
随机推荐
- 大数据入门第十六天——流式计算之storm详解(二)常用命令与wc实例
			一.常用命令 1.提交命令 提交任务命令格式:storm jar [jar路径] [拓扑包名.拓扑类名] [拓扑名称] torm jar examples/storm-starter/storm-st ... 
- STM32之HAL库、标准外设库、LL库
			标准外设库(Standard Peripherals Library),应该是最早推出的版本,以前用STM32F103的时候,用的多 HAL(Hardware Abstraction Layer),硬 ... 
- *args和**kwargs在python中的作用
			我发现PYTHON新手在理解*args和**kwargs这两个魔法变量的时候有些困难.他们到底是什么呢? 首先,我先告诉大家一件事情,完整地写*args和**kwargs是不必要的,我们可以只写*和* ... 
- vs编译器好多下划波浪线但不报错
			解决办法:项目属性->c/c++->常规->附加包含目录->$(ProjectDir): $(ProjectDir) 项目的目录(定义形式:驱动器 + 路径):包括尾部的反斜杠 ... 
- centos7 部署 nginx+tomcat+MariaDB 环境并安装安全狗,使用natapp隧道
			jdk安装: -openjdk 参考:https://blog.csdn.net/dhr201499/article/details/81626466 tomcat安装: 使用版本:8.5.37 参考 ... 
- 微信小程序之地理位置授权 wx.getLocation
			1. 授权地理位置 点击按钮,弹出授权弹窗,点击允许后,在以后的操作中可以随时获取到用户地理位置 点击拒绝后,将无法获取到地理位置,也无法再次点击弹出弹窗. <button bindtap='o ... 
- SQL Server 全文搜索
			SQL Server 的全文搜索(Full-Text Search)是基于分词的文本检索功能,依赖于全文索引.全文索引不同于传统的平衡树(B-Tree)索引和列存储索引,它是由数据表构成的,称作倒转索 ... 
- .NetCore利用BlockingCollection实现简易消息队列
			前言 消息队列现今的应用场景越来越大,常用的有RabbmitMQ和KafKa. 我们用BlockingCollection来实现简单的消息队列. 实现消息队列 用Vs2017创建一个控制台应用程序.创 ... 
- 简单测评拨号VPS——云立方&淘宝卖家
			做爬虫的同学不可避免地要使用代理IP,除了各网站公布的免费代理IP外,我们还可以选择拨号VPS,本文简单对两家(类)拨号VPS提供商进行测评,如有差错,欢迎指出,非常感谢. 使用过程 云立方 第一次听 ... 
- 金蝶盘点机PDA仓库条码管理家电类序列号扫描操作方法-采购入库单
			1.1. 采购入库单 传统的进销存管理软件需要人工识别商品品种,清点商品数量,然后再去人工手工在电脑上一行行的录入采购入库单.录单效率低,误差大. 如果使用汉码盘点机PDA,入库时,仓管员只需要手持 ... 
