2014 UESTC Training for Data Structures G - 程序设计竞赛

G - 程序设计竞赛

Time Limit: 3000/1000MS (Java/Others)
    Memory Limit: 65535/65535KB (Java/Others)

Submit Status

“你动规无力,图论不稳,数据结构松散,贪心迟钝,没一样像样的,就你还想和我同台竞技,做你的美梦!今天这场比赛,就是要让你知道你是多么的无能!!”

不训练,无以为战。有n项能力是ACM竞赛要求的,训练则能提升,忽略则会荒废。

这m天,你能做到如何。

Input

第一行两个整数n,m,分别表示有n项能力要求,共有m天。

第二行n个整数,第i个整数ai表示第i项能力的数值。

接下来m行,每行开始先读入一个整数si,表明这是一次询问还是一次能力变化。

si=0,表明这是一次询问,然后读入两个整数li,ri,表示询问在[li,ri]区间中任选一段连续序列,这段序列中所有能力值之和最大能是多少。

si=1,表明这是一次能力变化,然后读入两个整数xi,wi,表示第xi项能力变为了wi。

1≤n,m≤100000,?10000≤ai≤10000,1≤li≤ri≤n,1≤xi≤n,?10000≤wi≤10000

Output

有多少询问就输出多少行,每行输出一个整数,作为对该询问的回答。

Sample input and output











Sample Input Sample Output
4 4
1 2 3 4
0 1 3
1 3 -3
0 2 4
0 3 3

6
4
-3

题意大概是,给定一个序列,要求序列支持修改时间<=o(lgn),区间查询连续序列之和最大值时间<=o(lgn).

要用线段树,记录好多东东。。。。

我是加了4个记录

struct mm{

int left;

int right;

int l;

int r;

int data;

int sum;

}tree[400005]={};

Left,right 是区间范围,

.l是存当前区间从右开始最大的连续序列之和。

.r是存当前区间从左开始最大的连续序列之和。

.data 是存当前区间的最大的连续序列之和。

.sum是存当前区间的所有元素之和。

然后修改序列时就有

int g=l*2,h=l*2+1;

tree[l].l=max(tree[g].sum+tree[h].l,tree[g].l);

tree[l].r=max(tree[h].sum+tree[g].r,tree[h].r);

tree[l].sum=tree[g].sum+tree[h].sum;

tree[l].data=max(tree[g].r+tree[h].l,max(tree[g].data,tree[h].data));

从左开始最大的连续序列之和可以是

这两种情况,即max(tree[g].sum+tree[h].l,tree[g].l);

黑色表示该区间的最大的连续序列之和

从右开始同理。

而data就是

这三种情况

即max(tree[g].r+tree[h].l,max(tree[g].data,tree[h].data));

然后查找区间,suan是计算在L区间内从j到k的最大的连续序列之和,先要找到包含[j,k]的最小区间[L.left,L.right],然后就和上图一样了。

int suan(int l,int j,int k)

{

if (tree[l].left==j &&
tree[l].right==k) return tree[l].data;

if ((tree[l].left+tree[l].right)/2<j)
return suan(l*2+1,j,k);

if ((tree[l].left+tree[l].right)/2>=k)
return suan(l*2,j,k);

int g,h;

g=suanr(l*2,j);

h=suanl(l*2+1,k);

int a,s;

a=suan(l*2,j,(tree[l].left+tree[l].right)/2);

s=suan(l*2+1,(tree[l].left+tree[l].right)/2+1,k);

return max(g+h,max(a,s));

}

其中suanr和suanl是计算L区间从右或从左最大的连续序列之和。

int suanr(int l,int j)

{

if (tree[l].left==j) return tree[l].r;

if ((tree[l].right+tree[l].left)/2+1<=j)
return suanr(l*2+1,j);

return
max(tree[l*2+1].r,tree[l*2+1].sum+suanr(l*2,j));

}

int suanl(int l,int j)

{

if (tree[l].right==j) return tree[l].l;

if ((tree[l].right+tree[l].left)/2>=j)
return suanl(l*2,j);

return
max(tree[l*2].l,tree[l*2].sum+suanl(l*2+1,j));

}


#include <iostream>
#include<cstdio>
using namespace std;
int M;
struct mm{
int left;
int right;
int l;
int r;
int data;
int sum;
}tree[400005]={};
void build(int l,int j,int k)
{
tree[l].left=j;
tree[l].right=k;
if (j==k) return;
build(l*2,j,(j+k)/2);
build(l*2+1,(j+k)/2+1,k);
}
void cha(int l,int j,int light)
{
if (tree[l].right==tree[l].left) {
tree[l].l=tree[l].r=tree[l].sum=tree[l].data=light;
return;
}
if ((tree[l].right+tree[l].left)/2<j)
cha(l*2+1,j,light);
else cha(l*2,j,light);
int g=l*2,h=l*2+1;
tree[l].l=max(tree[g].sum+tree[h].l,tree[g].l);
tree[l].r=max(tree[h].sum+tree[g].r,tree[h].r);
tree[l].sum=tree[g].sum+tree[h].sum;
tree[l].data=max(tree[g].r+tree[h].l,max(tree[g].data,tree[h].data));
}
int suanr(int l,int j)
{
if (tree[l].left==j) return tree[l].r;
if ((tree[l].right+tree[l].left)/2+1<=j) return suanr(l*2+1,j);
return max(tree[l*2+1].r,tree[l*2+1].sum+suanr(l*2,j));
}
int suanl(int l,int j)
{
if (tree[l].right==j) return tree[l].l;
if ((tree[l].right+tree[l].left)/2>=j) return suanl(l*2,j);
return max(tree[l*2].l,tree[l*2].sum+suanl(l*2+1,j));
}
int suan(int l,int j,int k)
{
if (tree[l].left==j && tree[l].right==k) return tree[l].data;
if ((tree[l].left+tree[l].right)/2<j) return suan(l*2+1,j,k);
if ((tree[l].left+tree[l].right)/2>=k) return suan(l*2,j,k);
int g,h;
g=suanr(l*2,j);
h=suanl(l*2+1,k);
int a,s;
a=suan(l*2,j,(tree[l].left+tree[l].right)/2);
s=suan(l*2+1,(tree[l].left+tree[l].right)/2+1,k);
return max(g+h,max(a,s));
}
int main()
{
int g,h,j,k,l,n;
cin>>n>>M;
build(1,1,n);
for (j=1;j<=n;j++){
scanf("%d",&g);
cha(1,j,g);
}
for (j=1;j<=M;j++){
scanf("%d%d%d",&g,&h,&k);
if (g==1) cha(1,h,k);
else {
printf("%d\n",suan(1,h,k));
}
}
return 0;
}

2014 UESTC Training for Data Structures G - 程序设计竞赛,码迷,mamicode.com

时间: 2024-07-29 16:39:43

2014 UESTC Training for Data Structures G - 程序设计竞赛的相关文章

2014 UESTC Training for Data Structures H - Cookies Test

H - Cookies Test Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status As chief programmer at a cookie production plant you have many responsibilities, one of them being that the cookies produced and packag

2014 UESTC Training for Data Structures C - 东风不与周郎便

C - 东风不与周郎便 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status "揽二乔于东南兮,乐朝夕之与共" 一首铜雀台赋,将愤怒与恐惧散播在了孙吴大军之中. 对抗曹军,万事俱备,只欠东风. 现在已经找到n个风眼,这些风眼的东风有强有弱,诸葛亮说他每次祈风都能够将一段风眼的东风增强,但需人去帮他布阵.同时他需要时刻掌控风眼的状况,以确定下一步的

2014 UESTC Training for Data Structures A - Islands

A - Islands Time Limit: 30000/10000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status Deep in the Carribean, there is an island even stranger than the Monkey Island, dwelled by Horatio Torquemada Marley. Not only it has a re

2014 UESTC Training for Data Structures D - 长使英雄泪满襟

看出司马懿在等蜀军粮草不济,孔明于是下令分兵屯田以备久战. 司马懿日日只是闭营不出.孔明每日思虑对策至天明,却也无可奈何. 漫天星辰中有一类星叫做将星,它们随着将魂的燃烧会越发明亮. 今夜五丈原的星空格外璀璨. 司马懿一声轻叹.五丈原的星,要落了. Input 第一行输入三个整数,n,W,H,分别表示有n颗星,矩形宽W,高H,. 接下来n行,每行三个整数,xi,yi,wi.表示第i颗星星的在天空的位置是(xi,yi),亮度是wi. 1≤n≤100000,1≤W,H≤1000000,0≤x,y≤1

2014 UESTC Training for Data Structures K - 方师傅与栈

K - 方师傅与栈 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 方师傅有一个1?N的排列,排列的顺序是固定的,他想要把这个排列重新排列成他喜欢的顺序. 于是他买了一个栈,他会按顺序将排列扔进栈内,在某些时刻将栈顶元素取出,这样出栈后的排列就可以重新排序啦. 例如,原序列是1,2,他先将1入栈,再将2入栈,然后将2出栈,最后将1出栈,那么新序列就变

2014 UESTC Training for Data Structures J - 方师傅的01串

J - 方师傅的01串 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 方师傅过生日啦,于是蟹毛买了N个01串,想送给方师傅. 但是蟹毛觉得这些01串不够美,于是他想从中选出一些送给方师傅. 蟹毛对于p个01串的美值定义为: 这些01串的最长公共前缀的长度×p 所以蟹毛想从N个01串中选出一些,使得这些01串的美值最高. 请告诉蟹毛最好的美值是多少.

2014 UESTC Training for Data Structures F - 天下归晋

F - 天下归晋 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 晋朝统一天下已有十年,曹魏.孙吴.蜀汉这些曾与天下相争的王朝,都成为了过眼云烟,仅留于故事之中. "爷爷,讲嘛讲嘛,再讲一次赤壁之战的故事嘛!" "你个死小子,都讲多少遍了,还听!" "就是想听打仗嘛!" "你小子啊...行,

2014 UESTC Training for Data Structures E - 休生伤杜景死惊开

E - 休生伤杜景死惊开 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 陆伯言军陷八卦阵之中,分明只是一条直路,却怎的也走不到尽头.阵中尽是石堆,以某一石堆为参考,无论向走还是向右,总是会回到出发的石堆,最后幸得一黄姓老翁带路才得脱出. 陆伯言逃离八卦阵后,来到山顶观察此阵,记从左往右第i堆石堆的高度为Ai,发现任何两堆较矮的石堆都能和它们之间的一

2016 UESTC Training for Data Structures

2016 UESTC Training for Data Structures A - 卿学姐与公主 题意: 有两个操作一个是单点造成攻击,第二个是求区间最大值. 题解: 0.裸的线段树操作,不过zkw线段树显然更好. 代码: #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> using namespace std; const int N = 1000