UESTC - 1357 前缀和维护

Posted The Azure Arbitrator

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UESTC - 1357 前缀和维护相关的知识,希望对你有一定的参考价值。

有点小细节需要注意
sum实时维护有效的连续和

/*H E A D*/
ll dp1[maxn],dp2[maxn];
ll a[maxn],n,sum;
int main(){
    while(~iin(n)){
        rep(i,1,n) a[i]=read();
        dp1[0]=-(1ll<<62);dp2[n+1]=dp1[0];
//      rep(i,1,n) dp1[i]=max(dp1[i-1]+a[i],a[i]);//a[i]无论如何都加上去了 
//      rrep(i,n,1) dp2[i]=max(dp2[i+1]+a[i],a[i]);
        sum=0;
        rep(i,1,n){
            if(sum<0) sum=0;
            sum+=a[i];
            dp1[i]=max(dp1[i-1],sum);
        }
        sum=0;
        rrep(i,n,1){
            if(sum<0)sum=0;
            sum+=a[i];
            dp2[i]=max(dp2[i+1],sum);
        }
        ll ans=1ll<<63;ans=-ans;
        rep(i,2,n-1) ans=max(ans,dp1[i-1]+dp2[i+1]);
        println(ans);
    }
    return 0;
}

以上是关于UESTC - 1357 前缀和维护的主要内容,如果未能解决你的问题,请参考以下文章

1357. 优质牛肋骨一般 / 思维 爆搜

2018 UESTC Training for Search Algorithm & String

luogu P1357 花园

2017 UESTC Training for Search Algorithm & String

uestc 94(区间更新)

uestc oj 1217 The Battle of Chibi (dp + 离散化 + 树状数组)