首页 > 其他 > 详细

UESTC - 1357 前缀和维护

时间:2018-02-10 10:20:18      阅读:244      评论:0      收藏:0      [点我收藏+]

有点小细节需要注意
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 前缀和维护

原文:https://www.cnblogs.com/caturra/p/8437912.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!