最大子段和-DP方法
Description
给出N个数字, 计算出最大的子段和。
Input
第一行给出一个数字 T(1<=T<=20) 代表接下来的组数.
接下来每 T 行,开始给出一个正整数 N(1<=N<=100000), 接着跟着N个整数.。数据保证中间结果和最后结果都在int范围内。
Output
输出最大的字段和
Sample Input
2
5 6 -1 5 4 -7
7 0 6 -1 1 -6 7 -5
Sample Output
14
7
Code
#include<bits/stdc++.h>
using namespace std;
const int MAX=100005;
const long long inf=(1LL)<<61;
pair<int,int>ans;
void vInput(int nDataNum,int nArray[]);
int nMaxSum(int a[], int n);
void vOutput(int nSum);
int main()
{
int nNum,nT,nSum;
int nData[MAX];
cin >> nT;
while(nT--)
{
cin>>nNum;
vInput(nNum,nData);
nSum=nMaxSum(nData,nNum);
vOutput(nSum);
}
return 0;
};
void vInput(int nDataNum,int nArray[])
{
int i;
for(i=1;i<=nDataNum;i++){
cin >> nArray[i];
}
}
int nMaxSum(int a[], int n){
int nSum = 0;
int nCheck = 0;
for(int i = 0; i < n; i++){
if(nCheck > 0)
nCheck += a[i];
else
nCheck = a[i];
if(nCheck > nSum)
nSum = nCheck;
}
return nSum;
}
void vOutput(int nSum)
{
cout<< nSum << endl;
}