JenMorgan / js-learning

0 stars 0 forks source link

Подмассив наибольшей суммы #45

Open JenMorgan opened 4 years ago

JenMorgan commented 4 years ago

На входе массив чисел, например: arr = [1, -2, 3, 4, -9, 6].

Задача: найти непрерывный подмассив в arr, сумма элементов в котором максимальна.

Функция getMaxSubSum(arr) должна возвращать эту сумму.

Если все элементы отрицательные – ничего не берём(подмассив пустой) и сумма равна «0»:

JenMorgan commented 4 years ago
function getMaxSubSum(arr) {
    let allSums = [];
    let sumOfValues = 0;
    let n = 1;
    let sum = 0;
    for (let i = 0; i < arr.length; i++) {
        sumOfValues += arr[i];
        allSums.push(sumOfValues);
        let j = n;
        while (j < arr.length) {
            sum += arr[j];
            allSums.push(sum);
            j++;
        }
        n++;
        sum = 0;
    }
    const maxOfSums = Math.max.apply(null, allSums);
    return (maxOfSums < 0)? 0 : maxOfSums;
}

console.log(getMaxSubSum([-1, 2, 3, -9])) // 5 (сумма выделенных)
console.log(getMaxSubSum([2, -1, 2, 3, -9])) // 6
console.log(getMaxSubSum([-1, 2, 3, -9, 11])) // 11
console.log(getMaxSubSum([-2, -1, 1, 2])) // 3
console.log(getMaxSubSum([100, -9, 2, -3, 5])) // 100
console.log(getMaxSubSum([1, 2, 3])) // 6 (берём все)
console.log(getMaxSubSum([-1, -2, -3])) // 0
console.log(getMaxSubSum([1, 2, 3, 4])) // 10