題目描述:
輸入乙個整數陣列,陣列中有乙個或者多個連續的字串,求所有字串的和的最大值。
例如:輸入:1 -2 3 10 -4 7 2 -5
輸出:18
解題思路1:
動態規劃使用dp[i]來儲存以i結尾的最大連續子陣列的和,只需要求出max[dp[i]],即可得到最大連續子陣列的和。
當dp[i-1]+第i個元素比第二個元素大時,dp[i]賦值為dp[i-1]+第i個元素;否則直接賦值第i個元素。
解題思路2:
初始化和sum為最小整數,如果sum小於等於0,則將sum置為當前元素,並記錄開始元素為i(可能是最大值的開始);如果sum>0,則sum累加當前元素i;每次迴圈判斷是否是最大值。
解題思路1,**:
public static void main(string args) else
if(dp[i]>max)
max=dp[i];
}system.out.println(max);
}
解題思路2**如下:
public static void main(string args) else
if(sum>max)
}system.out.println(max);
}
求連續子陣列最大和
輸入乙個整形陣列,陣列裡有正數也有負數。陣列中連續的乙個或多個整數組成乙個子陣列,每個子陣列都有乙個和。求所有子陣列的和的最大值。例如輸入的陣列為 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...