數據結構:最大子序列和

 

算法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

相關文章
相關標籤/搜索