http://uva.onlinejudge.org/index.php?

option=com_onlinejudge&Itemid=8&page=show_problem&problem=3143

矩阵变成一行,然后计算位置。lrj给了线段树数组做法 可是我做的线段树空间过大,直接爆掉,所以换方法了

主要还是測试自己的线段树区间更新的模板

各种RE+WA之后AC,,,,。

做的时候出现的几个错误:

1、行和列弄错

2、build初始化的时候,mmin mmax 都初始化为0才对

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std; #define lson(i) l , mid , (i)*2
#define rson(i) mid + 1 , r , ((i)*2 +1)
#define ll rt*2
#define rr (rt*2+1) const int INFMIN = 0xffffffff;
const int INFMAX = 1000000009;//0x80000000;
const int MAXN = 30001000;
struct Node{
int l,r;
int mmax,mmin,sum,add,s;/*s去标记是不是被set*/
};
Node nodes[MAXN]; int mmax,mmin,sum;
void PushUp(int rt)
{
nodes[rt].mmax = max(nodes[ll].mmax,nodes[rr].mmax);
nodes[rt].mmin = min(nodes[ll].mmin,nodes[rr].mmin);
nodes[rt].sum = nodes[ll].sum + nodes[rr].sum;
}
void PushDown(int rt)
{
//if(nodes[rt].add && flag == 1)
if(nodes[rt].add)
{
nodes[ll].add += nodes[rt].add;
nodes[ll].mmin += nodes[rt].add;
nodes[ll].mmax += nodes[rt].add;
nodes[rr].add += nodes[rt].add;
nodes[rr].mmin += nodes[rt].add;
nodes[rr].mmax += nodes[rt].add; nodes[ll].sum += nodes[rt].add*(nodes[ll].r-nodes[ll].l+1);
nodes[rr].sum += nodes[rt].add*(nodes[rr].r-nodes[rr].l+1);
nodes[rt].add = 0;
}
//if(nodes[rt].s && flag == 2)
if(nodes[rt].s)
{
nodes[ll].s = nodes[rr].s=nodes[rt].s;
nodes[ll].mmin = nodes[ll].mmax = nodes[rr].mmax = nodes[rr].mmin = nodes[rt].mmax;
nodes[ll].sum = nodes[rt].mmin*(nodes[ll].r-nodes[ll].l+1);
nodes[rr].sum = nodes[rt].mmin*(nodes[rr].r-nodes[rr].l+1);
nodes[ll].add = nodes[rr].add = 0;//////////////
nodes[rt].s=0;
}
}
void Build(int l,int r,int rt)
{
nodes[rt].l=l;
nodes[rt].r=r;
nodes[rt].add =0;
nodes[rt].s=0;
nodes[rt].sum =0;
nodes[rt].mmin=0;
nodes[rt].mmax=0;
if(l == r)
{
//nodes[rt].mmin = nodes[rt].mmax = nodes[rt].sum =a[l];
nodes[rt].mmin = nodes[rt].mmax = nodes[rt].sum =0;////////////////
return ;
}
int mid = (nodes[rt].l+nodes[rt].r)/2;
Build(lson(rt));
Build(rson(rt));
//PushUp(rt);
} void Update(int l,int r,int add,int rt,int flag)
{
/////////////////////////////////////////////////////////////////
//printf("rt=%d l=%d r=%d add=%d flag =%d nodes[rt].l=%d nodes[rt].r=%d\n",rt,l,r,add,flag,nodes[rt].l,nodes[rt].r);
if(l<=nodes[rt].l && nodes[rt].r<=r)
{
if(flag == 1)/*increase*/
{
nodes[rt].mmax += add;
nodes[rt].mmin += add;
nodes[rt].add += add;
nodes[rt].sum += add*(nodes[rt].r-nodes[rt].l+1); }
else
{
nodes[rt].mmax = add;
nodes[rt].mmin = add;
nodes[rt].add=0;
nodes[rt].s=1;
nodes[rt].sum = add*(nodes[rt].r-nodes[rt].l+1);
}
return;
}
PushDown(rt);
int mid = (nodes[rt].l+nodes[rt].r)/2;
if(l<=mid)Update(l,r,add,ll,flag);
if(r>mid)Update(l,r,add,rr,flag);
PushUp(rt);
}
void Query(int l,int r,int rt)/*1表示mmin 2--mmax 3-sum*/
{
/////////////////////////////////////////////////////////////////
//printf("rt=%d l=%d r=%d nodes[rt].l=%d nodes[rt].r=%d\n",rt,l,r,nodes[rt].l,nodes[rt].r);
///////////////////////////////////////////////////////////////////////////
if(l<=nodes[rt].l && nodes[rt].r<=r)
{
mmin = min(mmin,nodes[rt].mmin);
mmax = max(mmax,nodes[rt].mmax);
sum += nodes[rt].sum;
return ;
}
PushDown(rt);
int mid = (nodes[rt].l+nodes[rt].r)/2;
if(l<=mid)Query(l,r,ll);
if(r>mid)Query(l,r,rr);
PushUp(rt);
}
void clr()/*每次查询之前使用*/
{
sum =0;
mmin=INFMAX;
mmax=INFMIN;
} int main()
{
//freopen("uva11992.txt","r",stdin);
int r,c,m,v,flag,x1,y1,x2,y2; while(scanf("%d%d%d",&r,&c,&m)!=EOF)
{
Build(1,r*c,1);
while(m--)
{
scanf("%d%d%d%d%d",&flag,&x1,&y1,&x2,&y2);
if(flag<3)
{
scanf("%d",&v);
for(int i=x1;i<=x2;i++)/*此处注意*/
{
///////////////////////////////////////////////////////////////
//printf("i=%d\n",i); Update(y1+(i-1)*c,y2+(i-1)*c,v,1,flag);
}
}
else
{
int anssum=0,ansmin=INFMAX,ansmax=INFMIN;
for(int i=x1;i<=x2;i++)
{
clr();
Query(y1+(i-1)*c,y2+(i-1)*c,1);
////////////////////////
// printf("**min=%d\n",mmin);
/////////////////
anssum+=sum;
ansmax=max(ansmax,mmax);
ansmin=min(ansmin,mmin);
}
printf("%d %d %d\n",anssum,ansmin,ansmax);
}
}
} return 0;
}

uva 11992 为矩阵更新查询段树的更多相关文章

  1. 【UVA】11992 - Fast Matrix Operations(段树模板)

    主体段树,要注意,因为有set和add操作,当慵懒的标志下推.递归优先set,后复发add,每次运行set行动add马克清0 WA了好几次是由于计算那一段的时候出问题了,可笑的是我对着模板找了一个多小 ...

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

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

  3. UVa 11992 Fast Matrix Operations (线段树,区间修改)

    题意:给出一个row*col的全0矩阵,有三种操作 1 x1 y1 x2 y2 v:将x1 <= row <= x2, y1 <= col <= y2里面的点全部增加v: 2 ...

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

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

  5. poj 3468 线段树区间更新/查询

    Description You have N integers, A1, A2, ... , AN. You need to deal with two kinds of operations. On ...

  6. HDU 6356.Glad You Came-线段树(区间更新+剪枝) (2018 Multi-University Training Contest 5 1007)

    6356.Glad You Came 题意就是给你一个随机生成函数,然后从随机函数里确定查询的左右区间以及要更新的val值.然后最后求一下异或和就可以了. 线段树,区间最大值和最小值维护一下,因为数据 ...

  7. HDU 6315.Naive Operations-线段树(两棵树合并)(区间单点更新、区间最值、区间求和)+思维 (2018 Multi-University Training Contest 2 1007)

    6315.Naive Operations 题意很好理解,但是因为区间求和求的是向下取整的a[i]/b[i],所以直接分数更新区间是不对的,所以反过来直接当a[i]==b[i]的时候,线段树对应的位置 ...

  8. lintocde-247-线段树的查询 II

    247-线段树的查询 II 对于一个数组,我们可以对其建立一棵 线段树, 每个结点存储一个额外的值 count 来代表这个结点所指代的数组区间内的元素个数. (数组中并不一定每个位置上都有元素) 实现 ...

  9. lintcode-202-线段树的查询

    202-线段树的查询 对于一个有n个数的整数数组,在对应的线段树中, 根节点所代表的区间为0-n-1, 每个节点有一个额外的属性max,值为该节点所代表的数组区间start到end内的最大值. 为Se ...

随机推荐

  1. HTML5文件上传还有进度条

    以下是自学it网--中级班上课笔记 网址:www.zixue.it 需要在chrome,ff,IE10下运行 html页面 <!DOCTYPE html> <html lang=&q ...

  2. DataReader和DataSet的区别以及使用

    DataReader和DataSet这两个对象都可以将检索的关系数据存储在内存中.它们在功能使用方面非常相似,但是它们不可以相互替换. 主要区别如表所示:   DataReader DataSet 数 ...

  3. Oracle varchar2最大支持长度(转)

    oerr ora 0650206502, 00000, "PL/SQL: numeric or value error%s"// *Cause: An arithmetic, nu ...

  4. BT5 firefox Flash插件问题

    今天在BT下安装了Nessus,好不容易安装好了,注册成功,本以为大功告成,但是在最后关头,却出现一个“未安装flash插件”错误,在bT下尝试着安装flahs插件,蛋碎一地,,,没能解决. 我的BT ...

  5. JAVA线程相互排斥问题

    public class TraditionalThreadSynchonized { public static void main(String[] args) { final OutPuter ...

  6. git使用ssh密钥和https两种认证方式汇总(转)

    在版本库的SSH方式和HTTPS方式是不同的,具体来说就是url信息的不同,但是,实际的认证机制也是不同的.当建立了本机密钥之后,使用ssh方式实际上是不需要再次认证的,而https则每次需要输入密码 ...

  7. HLG 2163 方格取数 (最大网络流)

    题目链接:  m=ProblemSet&a=showProblem&problem_id=2163">点击打开链接 Description : 给你一个n*n的格子的棋 ...

  8. hdu2845(dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2845 题意:给你一个n*m的矩阵,每个位置有一定数量的豆子,如果你去map[x][y]位置上的豆子,则 ...

  9. SQL Syscolumns

    每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行.该表位于每个数据库中. 列名 数据类型 描述 name sysname 列名或过程参数的名称. id int 该列所属的表对象 I ...

  10. SE 2014年4月12日

    BGP基础实验 拓扑 步骤: 1. 完成基本的配置 2. 按照需求自治系统AS 100 全网运行OSPF 单区域 3. 完成BGP基本配置 [RT2]bgp 100 [RT2-bgp]peer 67. ...