最大子数组-两种方式

164 阅读1分钟
function getMaxSubSum(arr){
    let maxSum = 0;
    for(let i = 0; i < arr.length; i++){
    	let sum = 0;
        for(let j = i; j < arr.length; j++){
        	sum += arr[j];
            maxSum = Math.max(sum,maxSum);
        }
    }
    
    return maxSum
}

思路:列出所有子集并计算子集的和,取最大和,复杂度为O(n^2)

function getMaxSubSum(arr) {
    let maxSum = 0;
    let pos = 0;

    for(let i of arr){
        pos += i;
        maxSum = Math.max(maxSum,pos);
        if(pos < 0) pos = 0;
    }

    return maxSum
}

思路:遍历数组,将当前局部元素的和保存在变量 s 中。如果 s 在某一点变成负数了,就重新分配 s=0。所有 s 中的最大值就是答案