poj 2479 Maximum sum (最大字段和的变形)

题目链接:http://poj.org/problem?id=2479

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

const int maxn = 50005;
const int INF = 0x3f3f3f3f;

int dp1[maxn];
int dp2[maxn];
int a[maxn];
int N;

int main()
{
    int T;
    cin>>T;
    while(T--){
        scanf("%d",&N);
        for(int i=1;i<=N;i++) scanf("%d",&a[i]);
        dp1[0] = -INF;
        for(int i=1;i<=N;i++){
            dp1[i] = max(dp1[i-1],0) + a[i];
        }
        for(int i=2;i<=N;i++)
            dp1[i] = max(dp1[i],dp1[i-1]);

        dp2[N+1] = -INF;
        for(int i=N;i>=1;i--){
            dp2[i] = max(dp2[i+1],0) + a[i];
        }
        for(int i=N-1;i>=1;i--){
            dp2[i] = max(dp2[i],dp2[i+1]);
        }
        int ans = -INF;
        for(int i=1;i<=N;i++)
            ans = max(ans,dp1[i]+dp2[i+1]);
        printf("%d\n",ans);
    }
}
View Code

 

posted @ 2013-08-28 08:51  等待最好的两个人  阅读(141)  评论(0编辑  收藏  举报