算法1:時間複雜度大而且不是很能理解,故不做展現算法
算法2:blog
int MaxSubseqSum2(int A[], int N)
{
int ThisSum, MaxSum = 0;
int i, j, k;
for (i = 0; i<N; i++) //i是子列左端位置
{
ThisSum = 0; //ThisSum是從A[i]到A[j]的子列和
for (j = i; j<N; j++) //j是子列右端位置
{
ThisSum += A[j];
if (ThisSum > MaxSum) //若是剛獲得的這個子列和更大
{
MaxSum = ThisSum; //則更新結果
}
} //j循環結束
} //i循環結束
return MaxSum;
}循環
時間複雜度n*nim
算法3:分而治之 d3
時間複雜度nlognimg
算法4:在線處理 每次輸入一個值則當即計算時間
int MaxSubseqSum4(int A[], int N)
{
int ThisSum, MaxSum;
int i;
ThisSum = MaxSum = 0;
for (i=0; i < N; i++)
{
ThisSum += A[i];
if (ThisSum > MaxSum)
{
MaxSum = ThisSum;
}
else if (ThisSum < 0)
{
ThisSum = 0;
}
}
return MaxSum;
}co