思路

注意到最多20行,拆成20颗线段树即可

注意set标记清空左右儿子的add,不要清空自己的add,因为这个set操作之后可能还有add存在这个节点上

代码

#include <cstdio>
#include <algorithm>
#include <cstring>
#define int long long
using namespace std;
struct Node{
int minx,maxx,sum,add,set,lson,rson;
}Seg[5000000];
struct QNode{
int minx,maxx,sum;
};
int Nodecnt,r,c,m,root[30];
void pushup(int o){
Seg[o].sum=Seg[Seg[o].lson].sum+Seg[Seg[o].rson].sum;
Seg[o].maxx=max(Seg[Seg[o].lson].maxx,Seg[Seg[o].rson].maxx);
Seg[o].minx=min(Seg[Seg[o].lson].minx,Seg[Seg[o].rson].minx);
}
int New_Node(void){
int o=++Nodecnt;
Seg[o].add=Seg[o].lson=Seg[o].rson=Seg[o].maxx=Seg[o].minx=Seg[o].sum=0;
Seg[o].set=-1;
return o;
}
void pushdown(int o,int l,int r){
int mid=(l+r)>>1;
if(!Seg[o].lson)
Seg[o].lson=New_Node();
if(!Seg[o].rson)
Seg[o].rson=New_Node();
if(Seg[o].set!=-1){
Seg[Seg[o].lson].set=Seg[o].set;
Seg[Seg[o].rson].set=Seg[o].set;
Seg[Seg[o].lson].sum=Seg[o].set*(mid-l+1);
Seg[Seg[o].rson].sum=Seg[o].set*(r-mid);
Seg[Seg[o].lson].maxx=Seg[o].set;
Seg[Seg[o].rson].maxx=Seg[o].set;
Seg[Seg[o].lson].minx=Seg[o].set;
Seg[Seg[o].rson].minx=Seg[o].set;
Seg[Seg[o].lson].add=0;
Seg[Seg[o].rson].add=0;
Seg[o].set=-1;
}
if(Seg[o].add){
Seg[Seg[o].lson].add+=Seg[o].add;
Seg[Seg[o].rson].add+=Seg[o].add;
Seg[Seg[o].lson].sum+=Seg[o].add*(mid-l+1);
Seg[Seg[o].rson].sum+=Seg[o].add*(r-mid);
Seg[Seg[o].lson].maxx+=Seg[o].add;
Seg[Seg[o].rson].maxx+=Seg[o].add;
Seg[Seg[o].lson].minx+=Seg[o].add;
Seg[Seg[o].rson].minx+=Seg[o].add;
Seg[o].add=0;
}
}
void add(int L,int R,int l,int r,int &o,int c){
if(!o)
o=New_Node();
if(L<=l&&r<=R){
Seg[o].add+=c;
Seg[o].maxx+=c;
Seg[o].minx+=c;
Seg[o].sum+=c*(r-l+1);
return;
}
pushdown(o,l,r);
int mid=(l+r)>>1;
if(L<=mid)
add(L,R,l,mid,Seg[o].lson,c);
if(R>mid)
add(L,R,mid+1,r,Seg[o].rson,c);
pushup(o);
}
void set(int L,int R,int l,int r,int &o,int c){
if(!o)
o=New_Node();
if(L<=l&&r<=R){
Seg[o].add=0;
Seg[o].set=c;
Seg[o].maxx=c;
Seg[o].minx=c;
Seg[o].sum=c*(r-l+1);
return;
}
pushdown(o,l,r);
int mid=(l+r)>>1;
if(L<=mid)
set(L,R,l,mid,Seg[o].lson,c);
if(R>mid)
set(L,R,mid+1,r,Seg[o].rson,c);
pushup(o);
}
QNode query(int L,int R,int l,int r,int &o){
if(!o)
o=New_Node();
QNode tmp;
if(L<=l&&r<=R){
tmp.maxx=Seg[o].maxx;
tmp.minx=Seg[o].minx;
tmp.sum=Seg[o].sum;
return tmp;
}
pushdown(o,l,r);
int mid=(l+r)>>1;
if(R<=mid)
return query(L,R,l,mid,Seg[o].lson);
else if(L>mid)
return query(L,R,mid+1,r,Seg[o].rson);
else{
QNode lx,rx;
lx=query(L,R,l,mid,Seg[o].lson);
rx=query(L,R,mid+1,r,Seg[o].rson);
tmp.minx=min(lx.minx,rx.minx);
tmp.maxx=max(lx.maxx,rx.maxx);
tmp.sum=lx.sum+rx.sum;
return tmp;
}
}
void init(void){
Nodecnt=0;
memset(root,0,sizeof(root));
Seg[0].maxx=-0x3f3f3f3f;
Seg[0].minx=0x3f3f3f3f;
Seg[0].sum=0;
}
signed main(){
// freopen("test.in","r",stdin);
// freopen("test.out","w",stdout);
while(scanf("%lld %lld %lld",&r,&c,&m)==3){
init();
int x1,y1,x2,y2,v,opt;
for(int i=1;i<=m;i++){
scanf("%lld %lld %lld %lld %lld",&opt,&x1,&y1,&x2,&y2);
if(opt==1){
scanf("%lld",&v);
for(int j=x1;j<=x2;j++)
add(y1,y2,1,c,root[j],v);
}
else if(opt==2){
scanf("%lld",&v);
for(int j=x1;j<=x2;j++)
set(y1,y2,1,c,root[j],v);
}
else{
QNode ans={0x3f3f3f3f,-0x3f3f3f3f,0},tmp;
for(int j=x1;j<=x2;j++){
tmp=query(y1,y2,1,c,root[j]);
ans.maxx=max(ans.maxx,tmp.maxx);
ans.minx=min(ans.minx,tmp.minx);
ans.sum=ans.sum+tmp.sum;
}
printf("%lld %lld %lld\n",ans.sum,ans.minx,ans.maxx);
}
}
// printf("0:%lld %lld %lld\n",Seg[0].maxx,Seg[0].minx,Seg[0].sum);
}
return 0;
}

UVA11992 Fast Matrix Operations的更多相关文章

  1. UVA11992 - Fast Matrix Operations(段树部分的变化)

    UVA11992 - Fast Matrix Operations(线段树区间改动) 题目链接 题目大意:给你个r*c的矩阵,初始化为0. 然后给你三种操作: 1 x1, y1, x2, y2, v ...

  2. [uva11992]Fast Matrix Operations(多延迟标记,二维线段树,区间更新)

    题目链接:https://vjudge.net/problem/UVA-11992 题意:n*m的矩阵,每次对一个子矩阵操作,有三种操作:加x,设置为x,查询.查询返回子矩阵和.最小值.最大值 n很小 ...

  3. Fast Matrix Operations

    A Simple Problem with Integers 每次将区间向下更新,或是用之前的方法,统计当前节点到父节点处的覆盖数目. #include <cstdio> #include ...

  4. UVA 11992 - Fast Matrix Operations(段树)

    UVA 11992 - Fast Matrix Operations 题目链接 题意:给定一个矩阵,3种操作,在一个矩阵中加入值a,设置值a.查询和 思路:因为最多20列,所以全然能够当作20个线段树 ...

  5. uva 11992 Fast Matrix Operations 线段树模板

    注意 setsetset 和 addvaddvaddv 标记的下传. 我们可以控制懒惰标记的优先级. 由于 setsetset 操作的优先级高于 addaddadd 操作,当下传 setsetset ...

  6. Fast Matrix Operations(UVA)11992

    UVA 11992 - Fast Matrix Operations 给定一个r*c(r<=20,r*c<=1e6)的矩阵,其元素都是0,现在对其子矩阵进行操作. 1 x1 y1 x2 y ...

  7. luogu题解 UVA11992 【Fast Matrix Operations】

    题目链接: https://www.luogu.org/problemnew/show/UVA11992 题目大意: 一个r*c的矩阵,一开始元素都是0,然后给你m次三种操作,分别是将一个子矩阵中所有 ...

  8. 线段树(多维+双成段更新) UVA 11992 Fast Matrix Operations

    题目传送门 题意:训练指南P207 分析:因为矩阵不超过20行,所以可以建20条线段的线段树,支持两个区间更新以及区间查询. #include <bits/stdc++.h> using ...

  9. UVA 11992 Fast Matrix Operations(线段树:区间修改)

    题目链接 2015-10-30 https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=s ...

随机推荐

  1. Java课程课后作业02之动手动脑

    一.编写一个方法,使用以上算法生成指定数目(比如1000个)的随机整数 数学算法原理: 可以使用的方法:Math中的random类以及random类,区别:Math中的random类只能用于生成随机数 ...

  2. CEditUI 控件使用

    SetLimitText(UINT nMax )  //设置文本限制字符数 参数为nMax为控件可接受的文本最大字节数 GetTextLength() //获得文本长度 参考文档:http://www ...

  3. windows服务安装 System.IO.FileLoadException

    报错如下: System.IO.FileLoadException: 未能加载文件或程序集“file:///D:\WindowsService\bin\Debug\WindowsService.exe ...

  4. Android启动页欢迎界面大全 (网址)

    地址:http://download.csdn.net/detail/u013424496/9539810

  5. [Luogu P1886]滑动窗口--单调队列入门

    题目描述 现在有一堆数字共N个数字(N<=10^6),以及一个大小为k的窗口.现在这个从左边开始向右滑动,每次滑动一个单位,求出每次滑动后窗口中的最大值和最小值. 例如: The array i ...

  6. Codeforces 1090A - Company Merging - [签到水题][2018-2019 Russia Open High School Programming Contest Problem A]

    题目链接:https://codeforces.com/contest/1090/problem/A A conglomerate consists of n companies. To make m ...

  7. Luogu 1071 - 潜伏者 - [字符串]

    题目链接:https://www.luogu.org/problemnew/show/P1071 题解: 模拟就完事儿了. 注意failed的情况有:出现一个 $f[x]$ 对应多个值:存在两个不同的 ...

  8. JS常见的字符串操作

    1.charAt() 获取字符串指定位置的字符    用法:strObj是字符串对象,index是指定的位置,(位置从0开始数) strObj.charAt(index) 2. indexOf() 方 ...

  9. ssh无输入密码登录问题

    每天一个Linux命令:ps命令 ssh原理和运用(一):远程登录 http://www.ruanyifeng.com/blog/2011/12/ssh_remote_login.html SSH是每 ...

  10. https://stackoverflow.com/questions/10423781/sql-data-range-min-max-category

    select phone,count(order_id) as c from table_recordgroup by phoneorder by c desc SELECT CASEWHEN (ag ...