【BZOJ1176】[Balkan2007]Mokia/【BZOJ2683】简单题 cdq分治
【BZOJ1176】[Balkan2007]Mokia
Description
维护一个W*W的矩阵,初始值均为S.每次操作可以增加某格子的权值,或询问某子矩阵的总权值.修改操作数M<=160000,询问数Q<=10000,W<=2000000.
Input
第一行两个整数,S,W;其中S为矩阵初始值;W为矩阵大小
接下来每行为一下三种输入之一(不包含引号):
"1 x y a"
"2 x1 y1 x2 y2"
"3"
输入1:你需要把(x,y)(第x行第y列)的格子权值增加a
输入2:你需要求出以左下角为(x1,y1),右上角为(x2,y2)的矩阵内所有格子的权值和,并输出
输入3:表示输入结束
Output
对于每个输入2,输出一行,即输入2的答案
Sample Input
1 2 3 3
2 1 1 3 3
1 2 2 2
2 2 2 3 4
3
Sample Output
5
HINT
保证答案不会超过int范围
【BZOJ2683】简单题
题意:和上面一样
题解:依旧是分治思路
我们将询问差分,拆成四个点分别求前缀和,然后将询问和修改一起按横坐标排序;
然后在跑cdq分治的时候,我们一边递归一边按照修改的时间进行归并排序。根据cdq分治的思想,我们在执行区间[l,r]时已经处理完[l,mid]和[mid+1,r]了,那么我们只需要处理[l,mid]中的修改对[mid+1,r]中的询问造成的影响。于是我们在跑归并排序的时候,将[l,mid]中的修改按照纵坐标插入树状数组,然后将[mid+1,r]中的询问按照纵坐标在树状数组上查找,再更新一下答案就好了
这代码我已经不怎么压行了,是不是可读性高了好多。。。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
int n,num,m;
const int maxn=200010;
struct node
{
int x,y,org,v,k;
}s[maxn];
int p[maxn],q[maxn],tr[maxn*10],ans[maxn];
//p是归并排序的顺序,q是p的复制
bool cmp(node a,node b)
{
if(a.x==b.x&&a.org==b.org) return a.y<b.y;
if(a.x==b.x) return a.org<b.org;
return a.x<b.x;
}
void updata(int a,int val)
{
for(int i=a;i<=n;i+=i&-i) tr[i]+=val;
}
int query(int a)
{
int i,ret=0;
for(i=a;i;i-=i&-i) ret+=tr[i];
return ret;
}
void dfs(int l,int r)
{
if(l==r)
{
p[l]=l;
return ;
}
int i,mid=l+r>>1,h1=l,h2=mid+1;
dfs(l,mid),dfs(mid+1,r);
for(i=l;i<=r;i++)
{
if(h2<=r&&(h1>mid||s[p[h1]].org>=s[p[h2]].org))
{
if(!s[p[h2]].k) ans[s[p[h2]].org]+=s[p[h2]].v*query(s[p[h2]].y);
q[i]=p[h2++];
}
else
{
if(s[p[h1]].k) updata(s[p[h1]].y,s[p[h1]].v);
q[i]=p[h1++];
}
}
for(i=l;i<=mid;i++) if(s[p[i]].k) updata(s[p[i]].y,-s[p[i]].v);
for(i=l;i<=r;i++) p[i]=q[i];
}
int main()
{
int i,a,b,c,d,e;
scanf("%d%d",&a,&n);
for(i=1;e!=3;i++)
{
scanf("%d",&e);
if(e==1)
{
scanf("%d%d%d",&a,&b,&c);
s[++num].x=a,s[num].y=b,s[num].org=m,s[num].k=1,s[num].v=c;
}
if(e==2)
{
scanf("%d%d%d%d",&a,&b,&c,&d),a--,b--;
s[num+1].org=s[num+2].org=s[num+3].org=s[num+4].org=++m;
s[num+1].k=s[num+2].k=s[num+3].k=s[num+4].k=0;
s[++num].x=a,s[num].y=b,s[num].v=1;
s[++num].x=a,s[num].y=d,s[num].v=-1;
s[++num].x=c,s[num].y=b,s[num].v=-1;
s[++num].x=c,s[num].y=d,s[num].v=1;
}
}
sort(s+1,s+num+1,cmp);
dfs(1,num);
for(i=1;i<=m;i++) printf("%d\n",ans[i]);
return 0;
}
【BZOJ1176】[Balkan2007]Mokia/【BZOJ2683】简单题 cdq分治的更多相关文章
- bzoj 1176: [Balkan2007]Mokia&&2683: 简单题 -- cdq分治
2683: 简单题 Time Limit: 50 Sec Memory Limit: 128 MB Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要 ...
- bzoj2683简单题 cdq分治
2683: 简单题 Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 1803 Solved: 731[Submit][Status][Discuss] ...
- BZOJ2683: 简单题(cdq分治 树状数组)
Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 2142 Solved: 874[Submit][Status][Discuss] Descripti ...
- Bzoj2683 简单题 [CDQ分治]
Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 1071 Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...
- 【bzoj1176】[Balkan2007]Mokia/【bzoj2683】简单题 CDQ分治+树状数组
bzoj1176 题目描述 维护一个W*W的矩阵,初始值均为S(题目描述有误,这里的S没有任何作用!).每次操作可以增加某格子的权值,或询问某子矩阵的总权值.修改操作数M<=160000,询问数 ...
- 【BZOJ-1176&2683】Mokia&简单题 CDQ分治
1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1854 Solved: 821[Submit][St ...
- BZOJ 2683: 简单题 [CDQ分治]
同上题 那你为什么又发一个? 因为我用另一种写法又写了一遍... 不用排序,$CDQ$分治的时候归并排序 快了1000ms... #include <iostream> #include ...
- BZOJ 2683 简单题 cdq分治+树状数组
题意:链接 **方法:**cdq分治+树状数组 解析: 首先对于这道题,看了范围之后.二维的数据结构是显然不能过的.于是我们可能会考虑把一维排序之后还有一位上数据结构什么的,然而cdq分治却可以非常好 ...
- BZOJ 2683: 简单题(CDQ 分治)
题面 Time Limit: 50 Sec Memory Limit: 128 MB Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要维护两种操作: ...
随机推荐
- 将DataFrame数据如何写入到Hive表中
1.将DataFrame数据如何写入到Hive表中?2.通过那个API实现创建spark临时表?3.如何将DataFrame数据写入hive指定数据表的分区中? 从spark1.2 到spark1.3 ...
- Netstat命令(windows下)
功能: 一般用于检验本机各端口的网络连接情况. 例子:检查本机3389远程连接端口是否可用 netstat -nao|find "3389" 查看某进程使用的端口号: netst ...
- perl 利用管道读取压缩文件内容
perl的文件句柄不仅支持普通文件, 还支持管道,今天需要统计一个fastq文件中的序列数和碱基数,而NGS的fastq文件一般都是gzip压缩的,所以 需要读取压缩文件中的内容,代码如下: my ( ...
- Python中tab键自动补全功能的配置
新手学习Python的时候,如何没有tab键补全功能,我感觉那将是一个噩梦,对于我们这种菜鸟来说,刚接触python,对一切都不了解,还好有前辈们的指导,学习一下,并记录下来,还没有学习这个功能小伙伴 ...
- jquery-包裹元素
1.wrap方法 在每个匹配的元素外层包上一个html元素 参数类型说明: 1)html字符串 $('p').wrap('<div></div>'); 传入的html标签也可以 ...
- Unity3D工程源码目录
2-0 暗黑破坏神3 链接:http://pan.baidu.com/s/1dEAUZoX 密码:cly4 2-1 炉石传说 客户端加服务器端 链接:http://pan.baidu.co ...
- 双十二“MathType”限时6折特惠
MathType是由美国Design Science公司开发功能强大的公式编辑器,专门用来对数学公式的编辑,与常见的文字处理软件和演示程序配合使用,能够在各种文档中加入复杂的数学公式和符号.双十二期间 ...
- ubuntu普通用户无法使用usdo命令
1.切换到root用户下,怎么切换就不用说了吧,不会的自己百度去. 2.添加sudo文件的写权限,命令是: chmod u+w /etc/sudoers 3.编辑sudoers文件 vi /etc/s ...
- ubuntu samba
Linux 下的文件共享利器 Samba 想必大家已经非常熟悉了,今天我们介绍下如何在Ubuntu 14.04中使用 Samba 共享网络文件.打印机和其它公共资源. 1.安装 Samba 和图形配置 ...
- Android Bigmap的操作(绘制,裁剪)
绘制 依据某一种颜色绘制Bitmap Bitmap resultBitmap = Bitmap.createBitmap(600,800,Bitmap.Config.ARGB_8888); resul ...