码迷,mamicode.com
首页 > 其他好文 > 详细

动态最大子段和

时间:2018-10-11 21:55:13      阅读:182      评论:0      收藏:0      [点我收藏+]

标签:odi   class   ++   ons   else   get   最大子段和   build   --   

#include <bits/stdc++.h>
using namespace std;
const int maxn=5e5+10;

inline int read(){
    int x=0,f=1;char ch;
    do{ch=getchar();if(ch==‘-‘)f=-1;}while(!isdigit(ch));
    do{x=x*10+ch-‘0‘;ch=getchar();}while(isdigit(ch));
    return f*x;
}

int n,m,a[maxn];
struct node{
    #define lson t[k].lc
    #define rson t[k].rc
    int lc,rc;
    int sum,lmax,rmax,dat;
}t[maxn<<1];
int tot=1;

inline void pushup(int k){
    t[k].sum=t[lson].sum+t[rson].sum;
    t[k].lmax=max(t[lson].lmax,t[lson].sum+t[rson].lmax);
    t[k].rmax=max(t[rson].rmax,t[rson].sum+t[lson].rmax);
    t[k].dat=max(max(t[lson].dat,t[rson].dat),t[lson].rmax+t[rson].lmax);
}

void build(int k,int l,int r){
    if(l==r){
        t[k].sum=t[k].lmax=t[k].rmax=t[k].dat=a[l];
        return;
    }
    int mid=l+r>>1;
    lson=++tot,build(lson,l,mid);
    rson=++tot,build(rson,mid+1,r);
    pushup(k);
}

void modify(int k,int l,int r,int pos,int val){
    if(l==r){
        t[k].sum=t[k].lmax=t[k].rmax=t[k].dat=val;
        return;
    }
    int mid=l+r>>1;
    if(pos<=mid)modify(lson,l,mid,pos,val);
    else modify(rson,mid+1,r,pos,val);
    pushup(k);
}

node query(int k,int l,int r,int x,int y){
    if(l==x&&r==y)return t[k];
    int mid=l+r>>1;
    if(y<=mid)return query(lson,l,mid,x,y);
    else if(x>mid)return query(rson,mid+1,r,x,y);
    else{
        node ls=query(lson,l,mid,x,mid);
        node rs=query(rson,mid+1,r,mid+1,y);
        node res;
        res.sum=ls.sum+rs.sum;
        res.lmax=max(ls.lmax,ls.sum+rs.lmax);
        res.rmax=max(rs.rmax,rs.sum+ls.rmax);
        res.dat=max(max(ls.dat,rs.dat),ls.rmax+rs.lmax);
        return res;
    }
}

void read_and_parse(){
    n=read(),m=read();
    for(int i=1;i<=n;i++)a[i]=read();
    build(1,1,n);
}

void solve(){
    while(m--){
        int k=read(),x=read(),y=read();
        if(k==1){
            if(x>y)swap(x,y);
            printf("%d\n",query(1,1,n,x,y).dat);
        }else modify(1,1,n,x,y);
    }
}

int main(){
    read_and_parse();
    solve();
    return 0;
}

动态最大子段和

标签:odi   class   ++   ons   else   get   最大子段和   build   --   

原文地址:https://www.cnblogs.com/wzj-xhjbk/p/9774669.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!