Как минимизировать время выполнения при выполнении вложения для l oop javascript - PullRequest
0 голосов
/ 24 апреля 2020

Как уменьшить время выполнения кода при выполнении вложенных циклов в javascript. Я объясняю мой пример кода ниже, который содержит некоторые вложенные для l oop.

let arr1 = [1, -3, 2, 3, 6, -1];
let arr2 = [4, 8, 9, -4, 1, -1, -8, -9];
let arr3 = [6, 3, -1, -3, 4, -2, 2, 4, 6, -12, -7];

function countZeroSumSubArray(arr) {
  let sum = 0;
  let counter = 0;

  for (let i = 0; i < arr.length; i++) {
    sum = 0;
    for (let j = i; j < arr.length; j++) {
      sum += arr[j];
      if (!sum) {
        ++counter;
      }
    }

  }
  return counter
}

console.log('amount:', countZeroSumSubArray(arr1))
console.log('amount:', countZeroSumSubArray(arr2))
console.log('amount:', countZeroSumSubArray(arr3))

Здесь я могу столкнуться с проблемой времени выполнения, если заданная длина моего массива слишком велика. Мне нужно сократить это время выполнения или реализовать какой-то другой способ, с помощью которого я могу уменьшить время выполнения и также получить правильный вывод.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...