cdq分治妙啊

(被改过题面的)原题:

dydxh所出的题目是这样的:
有一个N*N矩阵,给出一系列的修改和询问,修改是这样的:将(x,y)中的数字加上k,而询问是这样的:求(x1,y1)到(x2,y2)这个子矩阵内所有数字的和。
虽然这么高级的数据结构题mzx这种菜逼当然不会,但是由于dydxh给mzx留了一条没有强制在线的生路,所以mzx决定挑战一下这道题。

1<=N<=500000,操作数不超过200000个,操作1中的k为正整数,且不超过2000

思路很妙,知道为什么要这样做但是感觉考场上想不出来QAQ

首先询问容斥成4个前缀和问题,设时间轴为z,问题就变成询问z<qz,x<qx,y<qy里面的数总和是多少

然后就跟数星星很像了,排序x,这样右边的x保证比左边的x大,cdq分治z,树状数组y

看网上的做法和我之前想的有点不一样,我之前想的是想归并排序那样从将右边的队头和左边的队头比较,小的出队,先递归,再计算

网上比较多的做法是,先计算,左边的修改给右边的查询贡献,然后把时间轴<=mid的放到mid左边,>mid的放到右边,再递归下一层

感觉第二种对于我来说更好理解吧,比较贴合cdq分治的本质,现在还不能理解这两种写法的联系

听闵神说递归的效率非常低?我和山神的递归2.2s,闵神迭代0.4s……

还需要想一下迭代的写法啊

代码:

 #include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<queue>
#include<vector>
using namespace std;
int read(){int z=,mark=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-')mark=-; ch=getchar();}
while(ch>=''&&ch<=''){z=(z<<)+(z<<)+ch-''; ch=getchar();}
return z*mark;
}
struct cdd{int x,y,z,v,mk;}a[]; int tp=;
int n;
int e[],lbt[];
cdd q[]; int hd=;
int ans[];
int t=;
void gtlbt(){for(int i=;i<=;++i)lbt[i]=i&-i;}
void mdf(int x,int y){while(x<=n) e[x]+=y,x+=lbt[x];}
int qr(int x){int bwl=; while(x) bwl+=e[x],x-=lbt[x]; return bwl;}
//int qr(int x){int bwl=0; while(x) bwl+=e[x],x-=lbt[x];}
void dfs(int l,int r){
if(l==r) return ;
int md=(l+r)>>;
for(int i=l;i<=r;++i){
if(!a[i].mk && a[i].z<=md) mdf(a[i].y,a[i].v);
else if(a[i].mk && a[i].z>md)
ans[a[i].v]+=a[i].mk*qr(a[i].y);
}
for(int i=l;i<=r;++i)if(!a[i].mk && a[i].z<=md) mdf(a[i].y,-a[i].v);
int t1=l,t2=md+;
for(int i=l;i<=r;++i) q[(a[i].z<=md?t1:t2)++]=a[i];
for(int i=l;i<=r;++i) a[i]=q[i];
dfs(l,md),dfs(md+,r);
}
bool cmp(cdd x,cdd y){return (x.x==y.x)?((x.z==y.z)?x.y<y.y:x.z<y.z):x.x<y.x;}
int main(){//freopen("ddd.in","r",stdin);
gtlbt();
cin>>n;
int mk,x,y,z,v;
while((mk=read())!=){
if(mk==) a[++tp].mk=,a[tp].x=read(),a[tp].y=read(),a[tp].v=read(),a[tp].z=tp;
else{
x=read(),y=read(),z=read(),v=read();
a[++tp].mk=,a[tp].x=z,a[tp].y=v,a[tp].z=tp,a[tp].v=++t;
a[++tp].mk=,a[tp].x=x-,a[tp].y=y-,a[tp].z=tp,a[tp].v=t;
a[++tp].mk=-,a[tp].x=z,a[tp].y=y-,a[tp].z=tp,a[tp].v=t;
a[++tp].mk=-,a[tp].x=x-,a[tp].y=v,a[tp].z=tp,a[tp].v=t;
}
}
sort(a+,a+tp+,cmp);
dfs(,tp);
for(int i=;i<=t;++i) printf("%d\n",ans[i]);
return ;
}

【BZOJ2683】简单题的更多相关文章

  1. [BZOJ2683]简单题/[BZOJ1176][BalkanOI2007]Mokia

    [BZOJ2683]简单题 题目大意: 一个\(n\times n(n\le5\times10^5)\)的矩阵,初始时每个格子里的数全为\(0\).\(m(m\le2\times10^5)\)次操作, ...

  2. Bzoj2683 简单题

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1071  Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...

  3. bzoj2683简单题 cdq分治

    2683: 简单题 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1803  Solved: 731[Submit][Status][Discuss] ...

  4. bzoj2683简单题

    #include <iostream> #include <cstdio> #include <cmath> #include <algorithm> ...

  5. BZOJ2683: 简单题(cdq分治 树状数组)

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 2142  Solved: 874[Submit][Status][Discuss] Descripti ...

  6. BZOJ2683 简单题(CDQ分治)

    传送门 之前听别人说CDQ分治不难学,今天才知道果真如此.之前一直为自己想不到CDQ的方法二很不爽,今天终于是想出来了一道了,太弱-- cdq分治主要就是把整段区间分成两半,然后用左区间的值去更新右区 ...

  7. Bzoj2683 简单题 [CDQ分治]

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1071  Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...

  8. 【对询问分块】【主席树】bzoj2683 简单题

    对操作序列分块,每S次暴力重建主席树. 当S=sqrt(n*log(n))时,复杂度为O(m*sqrt(n*log(n))). 在线的. #include<cstdio> #include ...

  9. cdq分治——bzoj2683简单题

    https://www.lydsy.com/JudgeOnline/problem.php?id=2683 知识点:1.以操作的顺序进行分治  2.cdq分治维护矩阵 3.计算比mid小的给比mid大 ...

  10. [BZOJ2683][BZOJ4066]简单题

    [BZOJ2683][BZOJ4066]简单题 试题描述 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要维护两种操作: 命令 参数限制 内容 1 x y A 1<=x ...

随机推荐

  1. Android设计模式之单例模式

    定义 单例模式是一种常用的软件设计模式.在它的核心结构中只包含一个被称为单例的特殊类.通过单例模式可以保证系统中一个类只有一个实例 . 单例模式是设计模式中最简单的形式之一.这一模式的目的是使得类的一 ...

  2. git在eclipse中的配置 转载

    git在eclipse中的配置 转载 一_安装EGIT插件 http://download.eclipse.org/egit/updates/ 或者使用Eclipse Marketplace,搜索EG ...

  3. C#图片转换成二进制流并且保存到sql server数据库

    注意:我要存储文件二进制流的列的类型是text,不是image类型. 我已经实现了从数据库中读取text类型的二进制流,,现在就是不知道怎么存进去. 我的部分关键代码: StreamReader sr ...

  4. web安全问题分析及处理

    前言 这是我观看了<前端漏洞分析及处理-蔡慧芨>公开课之后的一个总结及简单实践体会.在可能的情况下我会把他们都实际操作一遍,更加深刻地体会前端安全的重要性. web安全问题有哪些 XSS- ...

  5. Python将列表作为栈和队列

    Collections中的各种方法 阅读目录(Content) 一.各种方法介绍 二.代码部分 回到顶部(go to top) 一.各种方法介绍 Counter 统计个数   elements  mo ...

  6. Mybatis学习总结-----mybatis中refid是什么意思(十)

    1.首先定义一个sql标签,一定要定义唯一id<sql id="Base_Column_List" >name,age</sql>2.然后通过id引用< ...

  7. cas 认证管理器

    CAS-默认的认证管理器:AuthenticationManagerImpl <bean id="authenticationManager" class="org ...

  8. POJ 3685 Matrix 二分 函数单调性 难度:2

      Memory Limit: 65536K Total Submissions: 4637   Accepted: 1180 Description Given a N × N matrix A, ...

  9. Oracle 等待事件 db file sequential read

    db file sequential read-数据文件顺序读取 等待事件: "db file sequential read" Reference Note (文档 ID 345 ...

  10. css 让div 置于最顶层而不被其他东西挡住

    今天遇到自己写的div被其他东西给挡住了,需要设置一个属性就成功了 设置:z-index:值:比如 z-index:999. 若值设置为为-1,代表为最底层. div的图层由div的style中的z- ...