#include <bits/stdc++.h>
using namespace std;
int a[10000+1024];
int main()
{
int k;
while(scanf("%d",&k)&&k){
for(int i=0;i<k;++i){
scanf("%d",a+i);
}
int maxsum=0x80000000,cursum=0;
int l=0,r=0,c_l=0,c_r=0;
for(int i=0;i<k;++i){
cursum+=a[i];
c_r=i;
if(maxsum<cursum){
maxsum=cursum;
l=c_l;
r=c_r;
}
if(cursum<0){
cursum=0;
c_l=c_r=i+1;
}
}
if(maxsum<0)
maxsum=0,l=0,r=k-1;
printf("%d %d %d\n",maxsum,a[l],a[r]);
}
return 0;
}
hdu1231 最大连续子序列
最新推荐文章于 2020-09-30 16:10:46 发布
本文介绍了一个使用C++实现的最大连续子序列求和算法。该算法能够找到数组中具有最大和的连续子序列,并输出该子序列的起始和结束元素。通过对输入数组进行遍历,动态更新当前子序列和及最大子序列和,最终确定最大连续子序列的具体位置。
588

被折叠的 条评论
为什么被折叠?



