第1行:整数序列的长度N(2 <= N <= 50000) 第2 - N + 1行:N个整数(-10^9 <= A[i] <= 10^9)
输出最大子段和。
6 -2 11 -4 13 -5 -2
20
#include<iostream> #include<algorithm> using namespace std; long long a[50005]; long long dp[50005]; int main() { int n; while(cin>>n){ for(int i=1;i<=n;i++){ cin>>a[i]; dp[i]=0; } long long Max=0; dp[0]=0; for(int i=1;i<=n;i++){ dp[i]=max(dp[i-1]+a[i],(long long)0); Max=max(Max,dp[i]); } cout<<Max<<endl; } return 0; }
原文:https://www.cnblogs.com/zuoyou151/p/10574115.html