题意:
给一列数,求某一个字序列使该字序列的数的和最大,输出该字序列的和
解法,
输入为a[0] a[1]......a[n-1]
保存状态d[0],d[1],,,,,d[n-1]
d[i]表示包含了a[i]的以a[i]开始的序列i,i+1,,n-1的最大值
状态转移就是当d[i+1]为正数时,d[i]=d[i+1]+a[i]
否则d[i]=a[i]
#include<iostream>
#include<algorithm>
#include<cstdio>
#define INT_MIN (-2147483647 - 1)
using namespace std;
int a[50100];
int d[50100];//d[i]表示包含i的以i开始的序列i,i+1,,n-1的最大值
int main()
{
int total;
cin>>total;
while(total--)
{
int n;
scanf("%d",&n);
for (int i = 0; i < n; i++)
{
scanf("%d",&a[i]);
}
d[n-1]=a[n-1];
for(int i=n-2;i>=0;i--)
{
if(d[i+1]>0)
{
d[i]=d[i+1]+a[i];
}
else
{
d[i]=a[i];
}
}
int ans=INT_MIN;
for(int i=0;i<n;i++)
{
if(d[i]>ans)
{
ans=d[i];
}
}
cout<<ans<<endl;
}
return 0;
}