求連續子陣列的最大和

2021-07-22 19:12:43 字數 974 閱讀 2924

題目一:給定乙個陣列,求該陣列的最大子陣列和【與求最長連續子陣列互為姊妹題】

題目二:給定乙個陣列,求該陣列的最大兩個子陣列的和(子陣列位置無重合)

解題一

// 子陣列的最大和[技巧法]

func getmaxsum(arr int) int

res := intmin

cur := 0

for _, ele := range arr

if cur < 0

} return res

}// 子陣列最大和[動態規劃法]

// dp[i]表示到num[i]的最大和,dp[i] = max(arr[i], arr[i]+dp[i-1])

func getmaxsum2(arr int) int

dp := make(int, len(arr))

dp[0] = arr[0]

for i := 1; i < len(arr); i++ else

} res := dp[0]

for _, ele := range dp

} return res

}

解題二:在上面題目思路的基礎上,求兩個子陣列的最大和,可以考慮將原陣列num劃分為兩部分left和right,即以當前元素為分界線(當前元素指第二個元素到倒數第二個元素),左邊最大和與右邊最大和,整個過程訪問完畢即求得最大和。**如下:

int subarraymaxsum2(int num)

int res = num[0] + right[1];

int lmaxsum = num[0];

cur = num[0];

for(int i=1; ireturn res;

}

求連續子陣列最大和

輸入乙個整形陣列,陣列裡有正數也有負數。陣列中連續的乙個或多個整數組成乙個子陣列,每個子陣列都有乙個和。求所有子陣列的和的最大值。例如輸入的陣列為 2,11,4,13,5,2 和最大的子陣列為11,4,13 因此輸出為該子陣列的和20。本題解法多種多樣,時間複雜度可以為 o n 3 o n 2 o ...

求連續子陣列的最大和

題目 在古老的一維模式識別中,常常需要計算連續子向量的最大和,當向量全為正數的時候,問題很好解決。但是,如果向量中包含負數,是否應該包含某個負數,並期望旁邊的正數會彌補它呢?例如 連續子向量的最大和為8 從第0個開始,到第3個為止 思路 從頭到尾逐個累加,儲存兩個值 當前和 最大和。public c...

求連續子陣列的最大和

一般考陣列的題目,重在挖掘數字時間的規律,只要找到規律就可以寫遞推關係式,很容易編寫基於迴圈的 或者是動態規劃的程式。第一種解法 基於sum更新的解法 class solution return summax 第二種解法 自低向上的遞迴 使用動態規劃 f i 以array i 為末尾元素的子陣列的和...