int max(int *a,int n)
{
int sum = a[0]; //此种情况的话 若全为负数会返回最大的负数
int tempSum = 0;
for(int i=0;i<n;i++)
{
if(tempSum>=0) //即当前a[i]之前的a[0...i-1]的和大于等于0即可相加
{
tempSum = tempsum + a[i];
}
else //相反情况的话,需要从当前a[i]开始算起
{
tempSum = a[i];
}
if(tempSum>sum)
{
sum = tempSum;
}
}
return sum;
}
参考: http://blog.youkuaiyun.com/v_JULY_v/article/details/6444021
寻找最大子序列和的算法

本文介绍了一种用于寻找给定整数数组中最大子序列和的算法。通过遍历数组并使用变量来跟踪当前子序列和以及全局最大和,该算法能够有效地解决这一问题。特别地,它考虑了当所有元素都为负数的情况,确保正确返回最大可能的负数和。
4244

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



