求連續子陣列的最大和

2021-10-06 14:31:15 字數 832 閱讀 6584

輸入乙個整形陣列(可能有正數和負數),求陣列中連續子陣列(最少有乙個元素)的最大和。

描述:輸入隨機整數的陣列

問題:求出該陣列的所有元素連續的,子陣列中,元素和最大的子陣列

示例1:

輸入陣列:[1,2,-3,5,7,-9];

輸出結果:[5,7]

示例2:

輸入陣列:[1,3,-3,5,7,-9,8];

輸出結果:[1,3,-3,5,7,]

答案:

let arr =[1

,-3,

7,-6

,2,-

2,6,

-3,4

,6,-

8];let length = arr.length;

let sum = arr[0]

;let max = arr[0]

;let resmax = max;

let startindex =0;

let endindex =0;

for(

let j=

0;j)else

if(sum > max)}if

(max >resmax)

}console.

log(

'最大和='

+ resmax +

' 起始下標='

+ startindex +

' 結束下標='

+ endindex)

;console.

log(arr.

slice

(startindex,endindex+1)

);

求連續子陣列最大和

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

求連續子陣列的最大和

題目一 給定乙個陣列,求該陣列的最大子陣列和 與求最長連續子陣列互為姊妹題 題目二 給定乙個陣列,求該陣列的最大兩個子陣列的和 子陣列位置無重合 解題一 子陣列的最大和 技巧法 func getmaxsum arr int int res intmin cur 0 for ele range arr...

求連續子陣列的最大和

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