数据结构(二维线段树,差分): NOI2012 魔幻棋盘


貌似想复杂了……
#include <iostream>
#include <cstring>
#include <cstdio>
#define mid ((l+r)>>1)
using namespace std;
const int maxn=;
const int maxm=;
int N,M,Q;
struct Array{
long long num[maxm];
long long *operator [](int x){
return &num[(x-)*M];
}
}a,b; long long ABS(long long x){return x>?x:-x;}
long long GCD(long long x,long long y){
return y?GCD(y,x%y):ABS(x);
} int cnt,ch[maxn][];
long long w[maxn]; void Merge(int &x,int p1,int p2,int l,int r){
if(!x)x=++cnt;
w[x]=GCD(w[p1],w[p2]);
if(l!=r){
Merge(ch[x][],ch[p1][],ch[p2][],l,mid);
Merge(ch[x][],ch[p1][],ch[p2][],mid+,r);
}
} void Build(int &x,int l,int r,long long t[]){
x=++cnt;
if(l==r){
w[x]=t[l];
return;
}
Build(ch[x][],l,mid,t);
Build(ch[x][],mid+,r,t);
w[x]=GCD(w[ch[x][]],w[ch[x][]]);
} int rt[maxm<<];
void Build(int x,int l,int r){
if(l==r){
Build(rt[x],,M,a[l]);
return;
}
Build(x<<,l,mid);
Build(x<<|,mid+,r);
Merge(rt[x],rt[x<<],rt[x<<|],,M);
} int x,y,tx,ty;
int tp,x1,y1,x2,y2;
long long d; void Change(int x,int l,int r,long long d){
if(l==r){w[x]+=d;return;}
if(mid>=ty)Change(ch[x][],l,mid,d);
else Change(ch[x][],mid+,r,d);
w[x]=GCD(w[ch[x][]],w[ch[x][]]);
} void Update(int x,int p1,int p2,int l,int r){
w[x]=GCD(w[p1],w[p2]);
if(l==r)return;
if(mid>=ty)Update(ch[x][],ch[p1][],ch[p2][],l,mid);
else Update(ch[x][],ch[p1][],ch[p2][],mid+,r);
} void Modify(int x,int l,int r,long long d){
if(l==r){
Change(rt[x],,M,d);
return;
}
if(mid>=tx)Modify(x<<,l,mid,d);
else Modify(x<<|,mid+,r,d);
Update(rt[x],rt[x<<],rt[x<<|],,M);
} long long Que(int x,int l,int r){
if(l>=y1&&r<=y2)
return w[x];
long long ret=;
if(mid>=y1)ret=Que(ch[x][],l,mid);
if(mid<y2)ret=GCD(ret,Que(ch[x][],mid+,r));
return ret;
} long long Query(int x,int l,int r){
if(l>=x1&&r<=x2)
return Que(rt[x],,M);
long long ret=;
if(mid>=x1)ret=Query(x<<,l,mid);
if(mid<x2)ret=GCD(ret,Query(x<<|,mid+,r));
return ret;
} int main(){
freopen("chessa.in","r",stdin);
freopen("chessa.out","w",stdout);
scanf("%d%d",&N,&M);
scanf("%d%d",&x,&y);
scanf("%d",&Q);
for(int i=;i<=N;i++)
for(int j=;j<=M;j++)
scanf("%lld",&b[i][j]);
for(int i=;i<=N;i++)
for(int j=;j<=M;j++){
a[i][j]=b[i][j];
if(i<x)a[i][j]-=b[i+][j];
if(i>x)a[i][j]-=b[i-][j];
if(j<y)a[i][j]-=b[i][j+];
if(j>y)a[i][j]-=b[i][j-];
if(i!=x&&j!=y)a[i][j]+=b[i+(i<x?:-)][j+(j<y?:-)];
} Build(,,N);
while(Q--){
scanf("%d",&tp);
scanf("%d%d",&x1,&y1);
scanf("%d%d",&x2,&y2);
if(tp==){
x1=x-x1;x2=x+x2;
y1=y-y1;y2=y+y2;
printf("%lld\n",Query(,,N));
}
if(tp==){
scanf("%lld",&d); {
if(x1<=x&&y1<=y){
tx=x1-;ty=y1-;
if(tx&&ty)Modify(,,N,d);
} if(x1<=x&&y1>y){
tx=x1-;ty=y1;
if(tx)Modify(,,N,-d);
} if(x1>x&&y1<=y){
tx=x1;ty=y1-;
if(ty)Modify(,,N,-d);
} if(x1>x&&y1>y){
tx=x1;ty=y1;
Modify(,,N,d);
}
} {
if(x1<=x&&y2<y){
tx=x1-;ty=y2;
if(tx)Modify(,,N,-d);
} if(x1<=x&&y2>=y){
tx=x1-;ty=y2+;
if(tx&&ty<=M)Modify(,,N,d);
} if(x1>x&&y2<y){
tx=x1;ty=y2;
Modify(,,N,d);
} if(x1>x&&y2>=y){
tx=x1;ty=y2+;
if(ty<=M)Modify(,,N,-d);
}
} {
if(x2<x&&y1<=y){
tx=x2;ty=y1-;
if(ty)Modify(,,N,-d);
} if(x2<x&&y1>y){
tx=x2;ty=y1;
Modify(,,N,d);
} if(x2>=x&&y1<=y){
tx=x2+;ty=y1-;
if(tx<=N&&ty)Modify(,,N,d);
} if(x2>=x&&y1>y){
tx=x2+;ty=y1;
if(tx<=N)Modify(,,N,-d);
}
} {
if(x2<x&&y2<y){
tx=x2;ty=y2;
Modify(,,N,d);
} if(x2<x&&y2>=y){
tx=x2;ty=y2+;
if(ty<=M)Modify(,,N,-d);
} if(x2>=x&&y2<y){
tx=x2+;ty=y2;
if(tx<=N)Modify(,,N,-d);
} if(x2>=x&&y2>=y){
tx=x2+;ty=y2+;
if(tx<=N&&ty<=M)Modify(,,N,d);
}
} if(x1<=x&&x2>=x){
if(y1<=y){
tx=x;ty=y1-;
if(ty)Modify(,,N,-d);
}
if(y1>y){
tx=x;ty=y1;
Modify(,,N,d);
} if(y2<y){
tx=x;ty=y2;
Modify(,,N,d);
}
if(y2>=y){
tx=x;ty=y2+;
if(ty<=M)Modify(,,N,-d);
}
} if(y1<=y&&y2>=y){
if(x1<=x){
tx=x1-;ty=y;
if(tx)Modify(,,N,-d);
}
if(x1>x){
tx=x1;ty=y;
Modify(,,N,d);
} if(x2<x){
tx=x2;ty=y;
Modify(,,N,d);
}
if(x2>=x){
tx=x2+;ty=y;
if(tx<=N)Modify(,,N,-d);
}
} if(x1<=x&&x2>=x&&y1<=y&&y2>=y){
tx=x;ty=y;
Modify(,,N,d);
}
}
}
return ;
}
数据结构(二维线段树,差分): NOI2012 魔幻棋盘的更多相关文章
- POJ 2155 Matrix (二维线段树)
Matrix Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 17226 Accepted: 6461 Descripti ...
- HDU 4819 Mosaic (二维线段树)
Mosaic Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 102400/102400 K (Java/Others)Total S ...
- BZOJ2877 NOI2012魔幻棋盘(二维线段树)
显然一个序列的gcd=gcd(其差分序列的gcd,序列中第一个数).于是一维情况直接线段树维护差分序列即可. 容易想到将该做法拓展到二维.于是考虑维护二维差分,查询时对差分矩阵求矩形的gcd,再对矩形 ...
- NOI 2012 魔幻棋盘 | 二维差分 + 二维线段树
题目:luogu 2086 二维线段树,按套路差分原矩阵,gcd( x1, x2, ……, xn ) = gcd( xi , x2 - x1 , ……, xn - xn-1 ),必须要有一个原数 xi ...
- [BZOJ2877][NOI2012]魔幻棋盘(二维线段树)
https://blog.sengxian.com/solutions/bzoj-2877 注意二维线段树的upd()也是一个O(log n)的函数(pushdown()应该也是但没写过). #inc ...
- tyvj P1716 - 上帝造题的七分钟 二维树状数组区间查询及修改 二维线段树
P1716 - 上帝造题的七分钟 From Riatre Normal (OI)总时限:50s 内存限制:128MB 代码长度限制:64KB 背景 Background 裸体就意味着 ...
- [JZOJ3615]【NOI2014模拟】数列(平面几何+二维线段树)
Description 给定一个长度为n的正整数数列a[i]. 定义2个位置的f值为两者位置差与数值差的和,即f(x,y)=|x-y|+|a[x]-a[y]|. 你需要写一个程序支持2种操作(k都是正 ...
- poj 2155 matrix 二维线段树 线段树套线段树
题意 一个$n*n$矩阵,初始全为0,每次翻转一个子矩阵,然后单点查找 题解 任意一种能维护二维平面的数据结构都可以 我这里写的是二维线段树,因为四分树的写法复杂度可能会退化,因此考虑用树套树实现二维 ...
- BZOJ 3489 A simple rmq problem 可持久化KDtree/二维线段树
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=3489 题意概述: 给出一个序列,每次询问一个序列区间中仅出现了一次的数字最大是多少,如果 ...
- bzoj 1513 POI2006 Tet-Tetris 3D 二维线段树+标记永久化
1511: [POI2006]OKR-Periods of Words Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 351 Solved: 220[S ...
随机推荐
- windows使用python调用wget批处理下载数据
wget是linux/unix下通常使用的下载http/ftp的数据,使用非常方便,其实wget目前经过编译,也可在windows下使用.最近需要下载大量的遥感数据,使用了python写了批处理下载程 ...
- oracle查看死锁和处理方法
在操作数据库中经常会遇到表死锁问题,特别是不良的数据库设计和操作的时候,更容易遇到死锁问题.今天在系统中往oracle中添加数据时,特意快速多点几次添加的时候,就出现了死锁问题,而且刚好在读取和更新表 ...
- Practice 15.07.07 计算几何 - 1
[题目在这里] A.POJ 2318 叉积判断点在直线的那一侧 cross(X2-X1,P-X1) (x1,x2是直线上两点,p是要判断的点) >0 表示在左侧 <0 表示在右侧 (右手 ...
- webUploader上传组件 实际运用小结
WebUploader组件实际介绍: 官网:http://fex.baidu.com/webuploader/doc/index.html 组件优势及优化总结:http://itindex.net/d ...
- Android开发需要注意的地方
1.理解运用商场概略 开发者对商场状况的理解与APP的胜利紧密相连,往常,AppStore和GooglePlay能够说是挪动运用最为丰厚的运用生态,像苹果的下载计算表单会记载抢手运用的下载 ...
- 分享最近写的 两条sql语句
1. 搭建基本环境 插入测试数据 insert into jgdm (jgdm,jgmc) values('12300000000','河南省');insert into jgdm (jgdm,jg ...
- iOS打包ipa安装包的流程
应用的发布也分两种 一种是.打包成ipa上传到国内第3方软件市场,当用户的手机已经JailBreak时,双击下载的ipa文件就可以安装软件 (ipa同android的apk包一样,实质是一个压缩包) ...
- js 模板引擎 - 超级强大
本来没想写这篇文章,但是网上误导大众的文章太多了,所以今天就抽出半小时时间谈一下我对前端模板引擎的感受吧. 前端模板引擎相信大家都再熟悉不过了,市面上非常多的号称最好.最快.最牛逼的,随便就能找到一大 ...
- Spring MVC中注解 @ModelAttribute
1.@ModelAttribute放在方法之上,在当前Control内的所有方法映射多个URL的请求,都会执行该方法 @ModelAttribute public void itemsCommon(H ...
- 【BZOJ1036】【树链剖分】树的统计Count
Description 一 棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. ...