uva 11992 为矩阵更新查询段树
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 为矩阵更新查询段树的更多相关文章
- 【UVA】11992 - Fast Matrix Operations(段树模板)
主体段树,要注意,因为有set和add操作,当慵懒的标志下推.递归优先set,后复发add,每次运行set行动add马克清0 WA了好几次是由于计算那一段的时候出问题了,可笑的是我对着模板找了一个多小 ...
- 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 (线段树,区间修改)
题意:给出一个row*col的全0矩阵,有三种操作 1 x1 y1 x2 y2 v:将x1 <= row <= x2, y1 <= col <= y2里面的点全部增加v: 2 ...
- UVA 11992 - Fast Matrix Operations(段树)
UVA 11992 - Fast Matrix Operations 题目链接 题意:给定一个矩阵,3种操作,在一个矩阵中加入值a,设置值a.查询和 思路:因为最多20列,所以全然能够当作20个线段树 ...
- poj 3468 线段树区间更新/查询
Description You have N integers, A1, A2, ... , AN. You need to deal with two kinds of operations. On ...
- HDU 6356.Glad You Came-线段树(区间更新+剪枝) (2018 Multi-University Training Contest 5 1007)
6356.Glad You Came 题意就是给你一个随机生成函数,然后从随机函数里确定查询的左右区间以及要更新的val值.然后最后求一下异或和就可以了. 线段树,区间最大值和最小值维护一下,因为数据 ...
- HDU 6315.Naive Operations-线段树(两棵树合并)(区间单点更新、区间最值、区间求和)+思维 (2018 Multi-University Training Contest 2 1007)
6315.Naive Operations 题意很好理解,但是因为区间求和求的是向下取整的a[i]/b[i],所以直接分数更新区间是不对的,所以反过来直接当a[i]==b[i]的时候,线段树对应的位置 ...
- lintocde-247-线段树的查询 II
247-线段树的查询 II 对于一个数组,我们可以对其建立一棵 线段树, 每个结点存储一个额外的值 count 来代表这个结点所指代的数组区间内的元素个数. (数组中并不一定每个位置上都有元素) 实现 ...
- lintcode-202-线段树的查询
202-线段树的查询 对于一个有n个数的整数数组,在对应的线段树中, 根节点所代表的区间为0-n-1, 每个节点有一个额外的属性max,值为该节点所代表的数组区间start到end内的最大值. 为Se ...
随机推荐
- cronjob不跑得原因
能是环境的不同,能够在cronjob中加个env > /tmp/env.output查看 应用要同一时候输出标准错误合标准输出到一个文件能够&> /tmp/t
- [Android]Volley源代码分析(店)应用
通过前面的谈话,我相信你有Volley有了一定的了解了原理.本章将给出一些我们的应用程序都可以在样品中直接使用,第一样品是 NetworkImageView类,事实上NetworkImageView顾 ...
- Codeforces 474B Worms 二分法(水
主题链接:http://codeforces.com/contest/474/problem/B #include <iostream> #include <cmath> #i ...
- 《转》在win7,boa-constructor 0.6.1 的palette面板中没有控件图标的解决方法
原地址:http://blog.csdn.net/rickleo/article/details/6532595 在win7-64bit环境下,boa-constructor 0.6.1 的palet ...
- A Game of Thrones(19) - Jon
The courtyard rang to the song of swords. Under black wool, boiled leather, and mail, sweat trickled ...
- brutal是什么意思_brutal在线翻译_英语_读音_用法_例句_海词词典
brutal是什么意思_brutal在线翻译_英语_读音_用法_例句_海词词典 brutal
- Android推断程序前后台状态
public class AppStatusService extends Service { private static final String TAG = "AppStatusSer ...
- hdu3062(two-sat)
传送门:Party 题意:有n对夫妻被邀请参加一个聚会,因为场地的问题,每对夫妻中只有1人可以列席.在2n 个人中,某些人之间有着很大的矛盾(当然夫妻之间是没有矛盾的),有矛盾的2个人是不会同时出现在 ...
- centos 更改hostname
vim /etc/hosts vim /etc/sysconfig/network hostname hostname mlzboy-centos63
- Loser应该知道的6个残酷人生事实(血泪翻译)
Loser应该知道的6个残酷人生事实(血泪翻译) - Acfun - 天下漫友是一家 Loser应该知道的6个残酷人生事实(血泪翻译)