首页 技术 正文
技术 2022年11月15日
0 收藏 966 点赞 2,683 浏览 2029 个字

给定长度为N的数列A,以及M条指令,每条指令可能是以下两种之一:

1、“1 x y”,查询区间 [x,y] 中的最大连续子段和,即 maxx≤l≤r≤ymaxx≤l≤r≤y{∑ri=lA[i]∑i=lrA[i]}。

2、“2 x y”,把 A[x] 改成 y。

对于每个查询指令,输出一个整数表示答案。

输入格式

第一行两个整数N,M。

第二行N个整数A[i]。

接下来M行每行3个整数k,x,y,k=1表示查询(此时如果x>y,请交换x,y),k=2表示修改。

输出格式

对于每个查询指令输出一个整数表示答案。

每个答案占一行。

数据范围

N≤500000,M≤100000N≤500000,M≤100000

输入样例:

5 3
1 2 -3 4 5
1 2 3
2 2 -1
1 3 2

输出样例:

2
-1
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
#include<stack>
#include<set>
#include<map>
#include<vector>
#include<cmath>const int maxn=5e5+;
typedef long long ll;
using namespace std;
struct node
{
int l,r;
ll sum,suml,sumr,summax;
}tree[maxn<<];
void pushup(int m)
{
tree[m].sum=(tree[m<<].sum+tree[m<<|].sum);
tree[m].summax=max(max(tree[m<<].summax,tree[m<<|].summax),tree[m<<].sumr+tree[m<<|].suml);
tree[m].suml=max(tree[m<<].suml,tree[m<<].sum+tree[m<<|].suml);
tree[m].sumr=max(tree[m<<|].sumr,tree[m<<].sumr+tree[m<<|].sum);
}
void build(int m,int l,int r)
{
tree[m].l=l;
tree[m].r=r;
if(l==r)
{
scanf("%lld",&tree[m].sum);
tree[m].summax=tree[m].sum;
tree[m].suml=tree[m].sum;
tree[m].sumr=tree[m].sum;
return ;
}
int mid=(l+r)>>;
build(m<<,l,mid);
build(m<<|,mid+,r);
pushup(m);
}
void update(int m,int pos,ll val)
{
if(tree[m].l==tree[m].r&&tree[m].l==pos)
{
tree[m].sum=val;
tree[m].summax=tree[m].sum;
tree[m].suml=tree[m].sum;
tree[m].sumr=tree[m].sum;
return ;
}
int mid=(tree[m].l+tree[m].r)>>;
if(pos<=mid)
{
update(m<<,pos,val);
}
else
{
update(m<<|,pos,val);
}
pushup(m);
}
node query(int m,int l,int r)
{
if(tree[m].l==l&&tree[m].r==r)
{
return tree[m];
}
int mid=(tree[m].l+tree[m].r)>>;
if(r<=mid)
{
return query(m<<,l,r);
}
else if(l>mid)
{
return query(m<<|,l,r);
}
else
{
node treel,treer,temp;
treel=query(m<<,l,mid);
treer=query(m<<|,mid+,r);
temp.sum=treel.sum+treer.sum;
temp.summax=max(max(treel.summax,treer.summax),treel.sumr+treer.suml);
temp.suml=max(treel.suml,treel.sum+treer.suml);
temp.sumr=max(treer.sumr,treer.sum+treel.sumr);
return temp;
}
}
int main()
{ int n,q;
cin>>n>>q;
build(,,n);
int op,l,r;
while(q--)
{
scanf("%d",&op);
if(op==)
{
scanf("%d%d",&l,&r);
if(l>r)
{
swap(l,r);
}
printf("%lld\n",query(,l,r).summax);
}
else
{
scanf("%d%d",&l,&r); update(,l,r);
}
}
return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,983
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,500
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,344
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,127
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,761
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,838