UVA 11992 Fast Matrix Operations (降维)
题意:对一个矩阵进行子矩阵操作。
元素最多有1e6个,树套树不好开(我不会),把二维坐标化成一维的,一个子矩阵操作分解成多条线段的操作。
一次操作的复杂度是RlogC,很容易找到极端的数据(OJ上实测没有),如果判断一下然后启发式建树复杂度是min(RlogC,ClogR)。
代码中结点没有保存l和r,而且询问是保存在全局变量中,这样做比较省空间。但是也有缺点,比如推区间结点数量的时候会麻烦一点。
#include<bits/stdc++.h>
using namespace std; const int maxn = 1e6+;
int R,C; #define lid (id<<1)
#define rid (id<<1|1)
struct Seg
{
int add,setv;
int Max,Min,sum;
}tr[maxn<<]; #define OP1(id,val)\
tr[id].add += val; tr[id].Max += val; tr[id].Min += val; tr[id].sum += (r-l+)*val;
#define OP2(id,val)\
tr[id].Max = tr[id].setv = tr[id].Min = val; tr[id].add = ; tr[id].sum = val*(r-l+); inline void push_down(int id,int l,int r)
{
int lc = lid, rc = rid, mid = (l+r)>>;
if(tr[id].setv>=){
int &t = tr[id].setv;
swap(r,mid);
OP2(lc,t);
swap(l,r); l++; swap(mid,r);
OP2(rc,t);
l--; swap(mid,l);
t = -;
}
if(tr[id].add>){
int &t = tr[id].add;
swap(r,mid);
OP1(lc,t);
swap(l,r); l++; swap(mid,r);
OP1(rc,t);
l--; swap(mid,l);
t = ;
}
} inline void maintain(int id)
{
int lc = lid, rc = rid;
tr[id].sum = tr[lc].sum + tr[rc].sum;
tr[id].Max = max(tr[lc].Max,tr[rc].Max);
tr[id].Min = min(tr[lc].Min,tr[rc].Min);
} int ql,qr,val;
void add1D(int l = ,int r = R*C-,int id = )
{
if(ql<=l&&r<=qr) { OP1(id,val) return; }
int mid = (l+r)>>, lc = lid, rc = rid;
push_down(id,l,r);
if(ql<=mid) add1D(l,mid,lc);
if(qr>mid) add1D(mid+,r,rc);
maintain(id);
} void set1D(int l = ,int r = R*C-,int id = )
{
if(ql<=l&&r<=qr) { OP2(id,val) return; }
int mid = (l+r)>>, lc = lid, rc = rid;
push_down(id,l,r);
if(ql<=mid) set1D(l,mid,lc);
if(qr>mid) set1D(mid+,r,rc);
maintain(id);
} int queryMax1D(int l = ,int r = R*C-,int id = )
{
if(ql<=l&&r<=qr) { return tr[id].Max; }
int mid = (l+r)>>, lc = lid, rc = rid;
push_down(id,l,r);
int ret = ;
if(ql<=mid) ret = max(ret,queryMax1D(l,mid,lc));
if(qr>mid) ret = max(ret,queryMax1D(mid+,r,rc));
return ret;
} const int INF = 0x3f3f3f3f; int queryMin1D(int l = ,int r = R*C-,int id = )
{
if(ql<=l&&r<=qr) { return tr[id].Min; }
int mid = (l+r)>>, lc = lid, rc = rid;
push_down(id,l,r);
int ret = INF;
if(ql<=mid) ret = min(ret,queryMin1D(l,mid,lc));
if(qr>mid) ret = min(ret,queryMin1D(mid+,r,rc));
return ret;
} int querySum1D(int l = ,int r = R*C-,int id = )
{
if(ql<=l&&r<=qr) { return tr[id].sum; }
int mid = (l+r)>>, lc = lid, rc = rid;
push_down(id,l,r);
int ret = ;
if(ql<=mid) ret += querySum1D(l,mid,lc);
if(qr>mid) ret += querySum1D(mid+,r,rc);
return ret;
} //[0,r)
void add2D(int x1,int y1,int x2,int y2,int v)
{
val = v;
int st = x1*C+y1, len = y2-y1;
for(int x = x1; x <= x2; x++){
ql = st; qr = st+len;
add1D();
st += C;
}
} void set2D(int x1,int y1,int x2,int y2,int v)
{
val = v;
int st = x1*C+y1, len = y2-y1;
for(int x = x1; x <= x2; x++){
ql = st; qr = st+len;
set1D();
st += C;
}
} int querySum2D(int x1,int y1,int x2,int y2)
{
int ret = ;
int st = x1*C+y1, len = y2-y1;
for(int x = x1; x <= x2; x++){
ql = st; qr = st+len;
ret += querySum1D();
st += C;
}
return ret;
} int queryMax2D(int x1,int y1,int x2,int y2)
{
int ret = ;
int st = x1*C+y1, len = y2-y1;
for(int x = x1; x <= x2; x++){
ql = st; qr = st+len;
ret = max(ret,queryMax1D());
st += C;
}
return ret;
} int queryMin2D(int x1,int y1,int x2,int y2)
{
int ret = INF;
int st = x1*C+y1, len = y2-y1;
for(int x = x1; x <= x2; x++){
ql = st; qr = st+len;
ret = min(ret,queryMin1D());
st += C;
}
return ret;
} int main()
{
//freopen("in.txt","r",stdin);
int m;
while(~scanf("%d%d%d",&R,&C,&m)){
ql = ; qr = R*C-; val = ;
set1D();
while(m--){
int op,x1,y1,x2,y2; scanf("%d%d%d%d%d",&op,&x1,&y1,&x2,&y2);
if(op == ){
int v; scanf("%d",&v);
add2D(x1-,y1-,x2-,y2-,v);
}else if(op == ){
int v; scanf("%d",&v);
set2D(x1-,y1-,x2-,y2-,v);
}else {
x1--;x2--;y1--;y2--;
printf("%d %d %d\n",querySum2D(x1,y1,x2,y2),queryMin2D(x1,y1,x2,y2),queryMax2D(x1,y1,x2,y2));
}
}
}
return ;
}
UVA 11992 Fast Matrix Operations (降维)的更多相关文章
- UVA 11992 - Fast Matrix Operations(段树)
UVA 11992 - Fast Matrix Operations 题目链接 题意:给定一个矩阵,3种操作,在一个矩阵中加入值a,设置值a.查询和 思路:因为最多20列,所以全然能够当作20个线段树 ...
- uva 11992 Fast Matrix Operations 线段树模板
注意 setsetset 和 addvaddvaddv 标记的下传. 我们可以控制懒惰标记的优先级. 由于 setsetset 操作的优先级高于 addaddadd 操作,当下传 setsetset ...
- UVA 11992 Fast Matrix Operations(线段树:区间修改)
题目链接 2015-10-30 https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=s ...
- 线段树(多维+双成段更新) UVA 11992 Fast Matrix Operations
题目传送门 题意:训练指南P207 分析:因为矩阵不超过20行,所以可以建20条线段的线段树,支持两个区间更新以及区间查询. #include <bits/stdc++.h> using ...
- UVA 11992 Fast Matrix Operations (二维线段树)
解法:因为至多20行,所以至多建20棵线段树,每行建一个.具体实现如下,有些复杂,慢慢看吧. #include <iostream> #include <cstdio> #in ...
- uva 11992 - Fast Matrix Operations
简单的线段树的题: 有两种方法写这个题,目前用的熟是这种慢点的: 不过不知道怎么老是T: 感觉网上A过的人的时间度都好小,但他们都是用数组实现的 难道是指针比数组慢? 好吧,以后多用数组写写吧! 超时 ...
- UVa 11992 Fast Matrix Operations (线段树,区间修改)
题意:给出一个row*col的全0矩阵,有三种操作 1 x1 y1 x2 y2 v:将x1 <= row <= x2, y1 <= col <= y2里面的点全部增加v: 2 ...
- 【UVA】11992 - Fast Matrix Operations(段树模板)
主体段树,要注意,因为有set和add操作,当慵懒的标志下推.递归优先set,后复发add,每次运行set行动add马克清0 WA了好几次是由于计算那一段的时候出问题了,可笑的是我对着模板找了一个多小 ...
- Fast Matrix Operations(UVA)11992
UVA 11992 - Fast Matrix Operations 给定一个r*c(r<=20,r*c<=1e6)的矩阵,其元素都是0,现在对其子矩阵进行操作. 1 x1 y1 x2 y ...
随机推荐
- 虚拟机出现ping DUP
在主机的网络连接里,停用虚拟网卡vmnet1和vmnet8,再启用虚拟网卡vmnet1和vmnet8.
- ASP.NET web application中的redirect
在开发ASP.NET MVC web application过程中,开发上线了新系统后,需要把老系统的url redirect新系统下 其中在项目系统目录下有一个文件 301RedirectsPage ...
- unity3d 自定义载入条/载入动画
在 Assets 下新建文件夹 WebGLTemplates , 在 WebGLTemplates 文件夹下新建文件夹 MyTemplate, 新建index. 在 PlayerSetting 中的 ...
- FZU 2219【贪心】
思路: 因为工人造完一个房子就死了,所以如果m<n则还需要n-m个工人. 最优的方案应该是耗时长的房子应该尽快建,而且最优的是越多的房子在建越好,也就是如果当前人数不到n,只派一个人去分裂. 解 ...
- codeforces 547B【单调栈】
题意: 有一个长度为n的序列,序列有长度为1...n的连续子序列, 一个连续子序列里面最小的值称作这个子序列的子序列的strength, 要求出每种长度的连续子序列的最大的strength. 思路: ...
- 洛谷P1014 Cantor表
P1014 Cantor表 题目描述 现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的.他是用下面这一张表来证明这一命题的: 1/1 1/2 1/3 1/4 1/5 … 2/1 ...
- SpringBoot2.0 基础案例(03):配置系统全局异常映射处理
一.异常分类 这里的异常分类从系统处理异常的角度看,主要分类两类:业务异常和系统异常. 1.业务异常 业务异常主要是一些可预见性异常,处理业务异常,用来提示用户的操作,提高系统的可操作性. 常见的业务 ...
- [Swift]LeetCode1079. 活字印刷 | Letter Tile Possibilities
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- SQL Server插入中文乱码
如果数据库的Collocation是英文的,字段是varchar类型,向表中插入中文数据,会出现乱码. 解决方法: 方法1. 修改varchar 为 nvarchar类型, 并在插入数据前加N,例如: ...
- spring boot 参数转换
参数调用方式: 1. localhost:8080/person/properties/to/json body参数设置: 2. localhost:8080/person/json/to/prope ...