bzoj1176 2683
我的第一道cdq分治题
清明做了一下cdq分治的几道题,感觉这个东西实在是太厉害了
离线大法好!关于几个经典的非数据结构做法具体可以看xhr神犇2013年的论文
应用cdq分治的前提条件是不强制在线,修改操作互不影响。
什么是互相影响,比如在第i个数后面插入一个数,这就明显是会影响到后面的操作
在这个前提条件下,我们可以按照操作序列的时间线(先后)划分成两个规模缩小一半的子问题
显然后面的修改对前面无影响,而后半部分的修改对后半部分的询问、前半部分对前半部分的询问是子问题,可以递归解决
所以下面我们只要解决前半部分的所有修改操作对后半部分询问答案的贡献即可
注意这里其实就相当于给出初始值不断进行无修改询问
也就是我们通过分治(1个log的代价,根据主定理可知),干掉了动态修改
回到这题上来,由于矩阵很大,不能支持二维数据结构,并且满足前提条件,所以用cdq分治
之后就变成了给定矩阵上一些值,求子矩阵和这样一个无修改的问题
注意这里询问满足减法性质,于是可以拆成四个询问,很显然对x排序,对y维护树状数组即可
具体做法间见程序注释(如果已经懂得了分治的框架写起来是非常轻松的)
注意bzoj1176和2683空间和范围略有不同
type node=record
op,ch,w,x,y:longint;
end; var c:array[..] of longint;
a,q:array[..] of node;
ans:array[..] of longint;
ch,pre,i,n,m,x,y,x1,y1,t:longint; function lowbit(x:longint):longint;
begin
exit(x and (-x));
end; function cmp(a,b:node):boolean; //注意这里要三个关键字排序,x,y,修改优先,为什么要自己想想
begin
if a.x<b.x then exit(true)
else if a.x=b.x then
begin
if a.y<b.y then exit(true)
else if (a.y=b.y) and (a.op<b.op) then exit(true);
end;
exit(false);
end; procedure swap(var a,b:node);
var c:node;
begin
c:=a;
a:=b;
b:=c;
end; procedure sort(l,r:longint);
var i,j:longint;
x:node;
begin
i:=l;
j:=r;
x:=q[(l+r) shr ];
repeat
while cmp(q[i],x) do inc(i);
while cmp(x,q[j]) do dec(j);
if not(i>j) then
begin
swap(q[i],q[j]);
inc(i);
dec(j);
end;
until i>j;
if l<j then sort(l,j);
if i<r then sort(i,r);
end; procedure add(x,w:longint);
begin
while x<=t do
begin
inc(c[x],w);
x:=x+lowbit(x);
end;
end; function ask(x:longint):longint;
begin
ask:=;
while x> do
begin
ask:=ask+c[x];
x:=x-lowbit(x);
end;
end; procedure cdq(l,r:longint);
var m,i,l1,l2:longint;
begin
if l=r then exit;
m:=(l+r) shr ;
for i:=l to r do
begin
if (q[i].ch<=m) and (q[i].op=-) then add(q[i].y,q[i].w); //前半部分修改
if (q[i].ch>m) and (q[i].op<>-) then inc(ans[q[i].w],ask(q[i].y)*q[i].op); //对后半部分查询影响
end;
for i:=l to r do //树状数组清0
if (q[i].ch<=m) and (q[i].op=-) then add(q[i].y,-q[i].w);
l1:=l; l2:=m+;
for i:=l to r do //按时间划分操作序列
if q[i].ch<=m then
begin
a[l1]:=q[i];
inc(l1);
end
else begin
a[l2]:=q[i];
inc(l2);
end; for i:=l to r do
q[i]:=a[i];
cdq(l,m);
cdq(m+,r);
end; begin
readln(pre,t);
while true do
begin
read(ch);
if ch= then break;
if ch= then
begin
inc(m);
q[m].ch:=m;
readln(q[m].x,q[m].y,q[m].w);
q[m].op:=-;
end
else begin
inc(n); inc(m);
readln(x,y,x1,y1);
q[m].w:=n; q[m].ch:=m; q[m].x:=x1; q[m].y:=y1; q[m].op:=;
inc(m);
q[m].w:=n; q[m].ch:=m; q[m].x:=x-; q[m].y:=y1; q[m].op:=-;
inc(m);
q[m].w:=n; q[m].ch:=m; q[m].x:=x1; q[m].y:=y-; q[m].op:=-;
inc(m);
q[m].w:=n; q[m].ch:=m; q[m].x:=x-; q[m].y:=y-; q[m].op:=;
end;
end;
sort(,m);
cdq(,m);
for i:= to n do
writeln(ans[i]);
end.
bzoj1176 2683的更多相关文章
- 【BZOJ-1176&2683】Mokia&简单题 CDQ分治
1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1854 Solved: 821[Submit][St ...
- 【bzoj1176】[Balkan2007]Mokia/【bzoj2683】简单题 CDQ分治+树状数组
bzoj1176 题目描述 维护一个W*W的矩阵,初始值均为S(题目描述有误,这里的S没有任何作用!).每次操作可以增加某格子的权值,或询问某子矩阵的总权值.修改操作数M<=160000,询问数 ...
- BZOJ 2683: 简单题
2683: 简单题 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 913 Solved: 379[Submit][Status][Discuss] ...
- [BZOJ2683]简单题/[BZOJ1176][BalkanOI2007]Mokia
[BZOJ2683]简单题 题目大意: 一个\(n\times n(n\le5\times10^5)\)的矩阵,初始时每个格子里的数全为\(0\).\(m(m\le2\times10^5)\)次操作, ...
- bzoj 1176: [Balkan2007]Mokia&&2683: 简单题 -- cdq分治
2683: 简单题 Time Limit: 50 Sec Memory Limit: 128 MB Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要 ...
- 【BZOJ1176】[Balkan2007]Mokia/【BZOJ2683】简单题 cdq分治
[BZOJ1176][Balkan2007]Mokia Description 维护一个W*W的矩阵,初始值均为S.每次操作可以增加某格子的权值,或询问某子矩阵的总权值.修改操作数M<=1600 ...
- 【BZOJ1176】Mokia(CDQ分治)
[BZOJ1176]Mokia(CDQ分治) 题面 BZOJ权限题啊,,,, dbzoj真好 Description 维护一个W*W的矩阵,初始值均为S.每次操作可以增加某格子的权值,或询问某子矩阵的 ...
- 【BZOJ1176】[BOI2007]Mokia 摩基亚
[BZOJ1176][BOI2007]Mokia 摩基亚 题面 bzoj 洛谷 题解 显然的\(CDQ\)\(/\)树套树题 然而根本不想写树套树,那就用\(CDQ\)吧... 考虑到点\((x1,y ...
- bzoj 4066 & bzoj 2683 简单题 —— K-D树(含重构)
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4066 https://www.lydsy.com/JudgeOnline/problem.p ...
随机推荐
- linux 下使用crontab 定时打包日志并删除已被打包的日志
crontab是和用户相关的,每个用户有自己对应的crontab . cron是Linux下的定时执行工具,以下是重启/关闭等等的命令 #/sbin/service crond start //启动服 ...
- docker+tomcat+java配置(ubuntu)
原创文章,转载请注明出处. 本文是基于ubuntu14.04搭建的dosker,tomcat配置是在docker容器外面(为了方便查看日志)使用的是docker启动挂载,该tomcat工程依赖于doc ...
- JS 获取 路径参数 传入 参数名 截取 & 和 # 之前 字符
function getQueryStringByName(name) { var result = location.search.match(new RegExp("[\?\&] ...
- GroupBox 重绘圆角边框和文字
private void GroupBox_Paint(object sender, PaintEventArgs e) { if (sender != null && sender ...
- CANVAS运用-对图片的压缩上传(仅针对移动浏览器)
最近在移动端设计头像上传功能时,原本是以<input type="file">直接通过formData上传,然而实际使用情况是:对于过大的图片(高像素手机所拍摄的照片等 ...
- PHP生成压缩文件开发实例
大概需求: 每一个订单都有多个文件附件,在下载的时候希望对当前订单的文件自动打包成一个压缩包下载 细节需求:当前订单号_年月日+时间.zip 例如: 1.生成压缩文件,压缩文件名格式: 2.压缩文件 ...
- PHP 5.6.6 上运行 ecshop 2.7.3 不兼容问题整合
在安装完php在自己的服务器上以后, 发现在静态网页上出现了很多 error. 在网上查找过后发现,大部分问题是因为 PHP发展到PHP5.5版本以后,有了很多细微的变化.而ECSHOP官方更新又太慢 ...
- 机器学习实战——k-近邻算法
本章内容 ================================ (一)什么是k-近邻分类算法 (二)怎样从文件中解析和导入数据 (三)使用Matplotlib创建扩散图 (四)对数据进行归 ...
- Django视图函数
一.视图函数 1. 视图函数的第一个参数一定是一个HTTPRequest类型的对象,这个对象是Django自动创建的,具体形参名通常用request.通过这个对象,可以调用请求的一些参数,比如requ ...
- 转:jQuery.fn.extend与jQuery.extend到底区别在哪?
还是先吐个槽,网上都都是转载抄袭,基本上就那么一两篇文章,说的还不清楚.... 正文: 其实说白了,从两个方法本身就能看出来端倪. 我们先把jQuery看成了一个类,这样好理解一些. jQuery.e ...