演算法4 求整型陣列的連續子陣列的最大和

2021-07-27 22:28:16 字數 908 閱讀 5392

輸入乙個整型陣列,陣列裡既有正數也有負數,陣列中連續乙個或者多個組成整型子陣列,每個子陣列都有乙個和,求所有子陣列的最大和,要求時間複雜度為o(n)。

使用貪婪演算法,陣列從開始往後遍歷,記錄最大和,當前和小於0時,當前子陣列和置為0.

//使用貪婪演算法,遇到sum<0的情況,就將sum置0

void getsubmaxsum(int srcbuffer,int srcbufferlen,int maxsubbuffer,int& maxsublength,int& maxsum)

maxsum = 0;

int maxsubbufferlen = 0;

intsum = 0;

int beginindex = 0;

int endindex = 0;

for(int i = 0; i < srcbufferlen; i++)

if(sum

<= 0)

}maxsublength = 0;

for(int i = beginindex; i <=endindex; i++)

}

int _tmain(int argc, _tchar* argv)

; cout

<<"please input 10 int valude"

int maxsubbuffer[srclength] = ;

int maxsum = 0;

int maxsublength = 0;

getsubmaxsum(srcbuffer,srclength,maxsubbuffer,maxsublength,maxsum);

cout

<<"maxsum = "

cout

0;}

演算法 求連續子陣列的最大和

題目描述 輸入乙個整數陣列,陣列中有乙個或者多個連續的字串,求所有字串的和的最大值。例如 輸入 1 2 3 10 4 7 2 5 輸出 18 解題思路1 動態規劃使用dp i 來儲存以i結尾的最大連續子陣列的和,只需要求出max dp i 即可得到最大連續子陣列的和。當dp i 1 第i個元素比第二...

求連續子陣列的最大和

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

求連續子陣列的最大和

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