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. perl 访问网站一些useragent的设置

    121.40.205.143 - - [22/Jun/2016:12:56:23 +0800] "GET /wechat/account.html HTTP/1.1" 200 34 ...

  2. ORA-00376:file x cannot be read at this time

    之前出现过机房断电情况,重启数据库后发现出现ORA-00376的错误. 通过查询数据文件状态: SQL> select file_id,online_status from dba_data_f ...

  3. operation is executing and cannot be enqueued

    http://d2100.com/questions/29022 作为依赖关系的另一个 NSOperation 添加时不调用 NSOperation dealloc 使用文书我看到很多我自定义的 NS ...

  4. POJ2584 T-Shirt Gumbo【二分图多重匹配】

    题目链接: id=2584">http://poj.org/problem?id=2584 题目大意: 如今有5种型号(S.M.L.X.T)的衣服要发放给N个參赛队员.给出每一个參赛者 ...

  5. oracle事务(转)

    今天温习oracle事务,记录如下: 事务定义            事务是保持数据的一致性,它由相关的DDL或者DML语句做为载体,这组语句执行的结果要么一起成功,要么一起失败.        我们 ...

  6. 【WinRT】【译】【加工】在 XAML 中制作圆形图片

    原文:[WinRT][译][加工]在 XAML 中制作圆形图片 原文地址:http://timheuer.com/blog/archive/2015/05/06/making-circular-ima ...

  7. centos 6.3 vnc连接—— catalog is not properly configured, attempting to determine an appropriate font p

    摘要:linux环境下,利用VNC连接远程桌面是经常用到的.这里,我们介绍centos上,利用VNC连接远程桌面的方法和常见的两个问题的解决方法1)由于字体问题,导致VNCserver无法启动 2)由 ...

  8. mysql登录报错 ERROR 1045 (28000)

    1.现象: [root@localhost ~]# mysql -u root -p Enter password:  ERROR 1045 (28000): Access denied for us ...

  9. Windows 10Bash命令

    Windows 10预览版14316开启Bash命令支持 00x0 前言 4月7日凌晨,微软推送了最新的Windows 10一周年更新预览版14316,其中重要的是原生支持Linux Bash命令行支 ...

  10. Redis在win7上的安装与可视化应用

    Redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set ...