求数组中最大子数组的和
#include<stdio.h>
int MaxSum3(int * A,int n){//优化方案 时间O(n) 空间 O(1)
int nStart=A[n-1];
int nAll=A[n-1];
for(int i=n-2;i>=0;i--){
if(nStart<0)
nStart=0;
nStart+=A[i];
if(nStart>nAll)
nAll=nStart;
}
return nAll;
}
int main()
{
for(int i=0;i<N;i++){
scanf("%d",&A[I]);
}
printf("%d",MaxSum3(A
,N));
return 0;
}
天街小雨润如酥,
草色遥看近却无。
最是一年春好处,
决胜烟柳满皇都。