æå¤§åæ°ç»
è¾å
¥æ¯ä»¥æ°åç»æçæ°ç»ï¼ä¾å¦ arr = [1, -2, 3, 4, -9, 6].
任塿¯ï¼æ¾åºææé¡¹çåæå¤§ç arr æ°ç»çè¿ç»åæ°ç»ã
ååºå½æ° getMaxSubSum(arr)ï¼ç¨å
¶æ¾åºå¹¶è¿åæå¤§åã
ä¾å¦ï¼
getMaxSubSum([-1, 2, 3, -9]) == 5ï¼é«äº®é¡¹çå åï¼
getMaxSubSum([2, -1, 2, 3, -9]) == 6
getMaxSubSum([-1, 2, 3, -9, 11]) == 11
getMaxSubSum([-2, -1, 1, 2]) == 3
getMaxSubSum([100, -9, 2, -3, 5]) == 100
getMaxSubSum([1, 2, 3]) == 6ï¼ææé¡¹çåï¼
妿ææé¡¹é½æ¯è´æ°ï¼é£å°±ä¸ä¸ªé¡¹ä¹ä¸åï¼åæ°ç»æ¯ç©ºçï¼ï¼æä»¥è¿åçæ¯ 0ï¼
getMaxSubSum([-1, -2, -3]) = 0
请å°è¯æ³åºä¸ä¸ªå¿«éçè§£å³æ¹æ¡ï¼å¤æåº¦å¯ä»¥æ¯ O(n2)ï¼æè½åè¾¾å° O(n) 忴好ã
æ ¢çè§£å³æ¹æ¡
æä»¬å¯ä»¥è®¡ç®ææå¯è½çåéçåã
æç®åçæ¹æ³å°±æ¯è·åæ¯ä¸ªå ç´ ç¶å计ç®ä»å®å¼å§ææåæ°ç»çåã
以 [-1, 2, 3, -9, 11] 为ä¾ï¼
// ä» -1 å¼å§ï¼
-1
-1 + 2
-1 + 2 + 3
-1 + 2 + 3 + (-9)
-1 + 2 + 3 + (-9) + 11
// ä» 2 å¼å§ï¼
2
2 + 3
2 + 3 + (-9)
2 + 3 + (-9) + 11
// ä» 3 å¼å§ï¼
3
3 + (-9)
3 + (-9) + 11
// ä» -9 å¼å§ï¼
-9
-9 + 11
// ä» 11 å¼å§ï¼
11
è¿æ ·ååºæ¥ç代ç å®é 䏿¯ä¸ä¸ªåµå¥å¾ªç¯ï¼å¤é¨å¾ªç¯éåæ°ç»ææå ç´ ï¼å é¨å¾ªç¯è®¡ç®ä»å½åå ç´ å¼å§çææåæ°ç»åèªçåã
function getMaxSubSum(arr) {
let maxSum = 0; // å¦ææ²¡æåå°ä»»ä½å
ç´ ï¼å°±è¿å 0
for (let i = 0; i < arr.length; i++) {
let sumFixedStart = 0;
for (let j = i; j < arr.length; j++) {
sumFixedStart += arr[j];
maxSum = Math.max(maxSum, sumFixedStart);
}
}
return maxSum;
}
alert( getMaxSubSum([-1, 2, 3, -9]) ); // 5
alert( getMaxSubSum([-1, 2, 3, -9, 11]) ); // 11
alert( getMaxSubSum([-2, -1, 1, 2]) ); // 3
alert( getMaxSubSum([1, 2, 3]) ); // 6
alert( getMaxSubSum([100, -9, 2, -3, 5]) ); // 100
è¯¥æ¹æ¡çæ¶é´å¤æåº¦æ¯ O(n2)ãä¹å°±æ¯è¯´ï¼å¦ææä»¬ææ°ç»å¤§å°å¢å 2 åï¼é£ä¹ç®æ³çè¿è¡æ¶é´å°ä¼å»¶é¿4åã
对äºå¤§åæ°ç»ï¼1000ï¼10000 æè æ´å¤é¡¹ï¼è¿ç§ç®æ³ä¼å¯¼è´ä¸¥éçæ¶é´æ¶èã
å¿«çè§£å³æ¹æ¡
让æä»¬éåæ°ç»ï¼å°å½åå±é¨å
ç´ çåä¿åå¨åé s ä¸ã妿 s 卿ä¸ç¹åæè´æ°äºï¼å°±éæ°åé
s=0ãææ s ä¸çæå¤§å¼å°±æ¯çæ¡ã
妿æåæè¿°ä¸å¤ªå¥½çè§£ï¼å°±ç´æ¥çä¸é¢ç代ç å§ï¼ççå¾çï¼
function getMaxSubSum(arr) {
let maxSum = 0;
let partialSum = 0;
for (let item of arr) { // arr ä¸çæ¯ä¸ª item
partialSum += item; // å°å
¶å å° partialSum
maxSum = Math.max(maxSum, partialSum); // è®°ä½æå¤§å¼
if (partialSum < 0) partialSum = 0; // 妿æ¯è´æ°å°±ç½®ä¸º 0
}
return maxSum;
}
alert( getMaxSubSum([-1, 2, 3, -9]) ); // 5
alert( getMaxSubSum([-1, 2, 3, -9, 11]) ); // 11
alert( getMaxSubSum([-2, -1, 1, 2]) ); // 3
alert( getMaxSubSum([100, -9, 2, -3, 5]) ); // 100
alert( getMaxSubSum([1, 2, 3]) ); // 6
alert( getMaxSubSum([-1, -2, -3]) ); // 0
è¯¥ç®æ³åªéè¦éå 1 è½®æ°ç»ï¼æä»¥æ¶é´å¤æåº¦æ¯ O(n)ã
ä½ ä¹å¯ä»¥å¨è¿è·åæ´å¤è¯¥ç®æ³çç»èä¿¡æ¯ï¼æå¤§åæ°ç»é®é¢ãå¦æè¿æ¯ä¸æç½ï¼é£å°±è°è¯ä¸é¢çä¾åï¼è§å¯å®æ¯ææ ·å·¥ä½çï¼è¯´å¾åå¤ä¹æ²¡æèªå·±å»è°è¯å¥½ä½¿ã
function getMaxSubSum(arr) {
let maxSum = 0;
let partialSum = 0;
for (let item of arr) {
partialSum += item;
maxSum = Math.max(maxSum, partialSum);
if (partialSum < 0) partialSum = 0;
}
return maxSum;
}