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. cronjob不跑得原因

    能是环境的不同,能够在cronjob中加个env > /tmp/env.output查看 应用要同一时候输出标准错误合标准输出到一个文件能够&> /tmp/t

  2. [Android]Volley源代码分析(店)应用

    通过前面的谈话,我相信你有Volley有了一定的了解了原理.本章将给出一些我们的应用程序都可以在样品中直接使用,第一样品是 NetworkImageView类,事实上NetworkImageView顾 ...

  3. Codeforces 474B Worms 二分法(水

    主题链接:http://codeforces.com/contest/474/problem/B #include <iostream> #include <cmath> #i ...

  4. 《转》在win7,boa-constructor 0.6.1 的palette面板中没有控件图标的解决方法

    原地址:http://blog.csdn.net/rickleo/article/details/6532595 在win7-64bit环境下,boa-constructor 0.6.1 的palet ...

  5. A Game of Thrones(19) - Jon

    The courtyard rang to the song of swords. Under black wool, boiled leather, and mail, sweat trickled ...

  6. brutal是什么意思_brutal在线翻译_英语_读音_用法_例句_海词词典

    brutal是什么意思_brutal在线翻译_英语_读音_用法_例句_海词词典 brutal

  7. Android推断程序前后台状态

    public class AppStatusService extends Service { private static final String TAG = "AppStatusSer ...

  8. hdu3062(two-sat)

    传送门:Party 题意:有n对夫妻被邀请参加一个聚会,因为场地的问题,每对夫妻中只有1人可以列席.在2n 个人中,某些人之间有着很大的矛盾(当然夫妻之间是没有矛盾的),有矛盾的2个人是不会同时出现在 ...

  9. centos 更改hostname

    vim /etc/hosts vim /etc/sysconfig/network hostname hostname mlzboy-centos63

  10. Loser应该知道的6个残酷人生事实(血泪翻译)

    Loser应该知道的6个残酷人生事实(血泪翻译) - Acfun - 天下漫友是一家 Loser应该知道的6个残酷人生事实(血泪翻译)