Удалить выбросы из в основном линейно увеличивающегося массива - PullRequest
0 голосов
/ 22 апреля 2019

Учитывая массив, который должен линейно увеличиваться, но в

  • могут отсутствовать некоторые числа, а
  • может содержать неожиданные числа,

как бы вы построили алгоритм для удаления всех выбросов из массива?

Примеры возможных массивов:

1,2,3,4,1,1,1,100,5,6,7

1,2,4,100,5,6,7

1,2,4,100,101,5,6,7,300

2,3, 4,5,6,7,300

Во всех приведенных выше примерах вы должны знать, что массив должен быть 1-7 или 2-7.

Некоторые примеры реальных массивов:

1, 2, 295, 296, 297, 4, 5, 6, 8, 9, 10, 11, 12, 13, 6, 6,6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 6, 6, 6, 6, 6, 5,5, 6, 6, 6, 6, 6, 4, 6, 6, 3, 4, 6, 6, 6, 5, 6, 6, 6, 4, 5, 6, 3, 6, 6, 6,6, 6, 6, 6, 5, 6, 6, 6, 6, 6, 4, 6, 3, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 3, 4, 6, 6, 6, 6, 6, 6, 5, 6, 6, 6, 3, 3, 6, 6, 6, 3, 6, 6, 4, 4, 6, 6, 6, 6, 6, 3, 6, 6, 6, 3, 6, 4, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 3, 6, 6, 3, 6, 6, 6, 6, 6, 6, 5, 6, 5, 5, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 3, 6, 6, 6, 6, 6, 6, 6, 15, 18, 20, 21, 22, 23, 24, 27, 28, 30, 31, 32, 33, 34, 35, 36, 37

1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11,12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 26, 712, 383, 114, 118, 225, 304, 323, 349, 357, 550, 556, 590, 649, 28,29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 51

Одно решение, которое я придумала, состоит в том, чтобы отфильтровать все значения, которые больше чем N (= 5?), Чем предыдущее допустимое значение, а также все значения, которые меньше, чем предыдущее допустимое значение.

const filterOutliers = (someArray) => {
  let previousValidValue = null;
  return someArray.filter((x, index) => {
    //Assume the first value is valid - although this assumption might not always be true.
    if(!previousValidValue) {
      previousValidValue = x;
      return true;
    }
    // if the number is less than the previous valid value, remove it
    if(x < previousValidValue) {
      return false;
    }
    // if the number is more than 5 greater than the last valid value, remove it
    if(x > previousValidValue + 5) {
      return false;
    }
    previousValidValue = x;
    return true;
  })
}

Потенциально релевантная ссылка: Javascript: удалить выброс из массива?

1 Ответ

0 голосов
/ 22 апреля 2019

Кажется, что ваши внутренние значения имеют постоянный прирост.Поэтому вычислите приращения, выберите режим и сохраните последовательности значений, которые следуют за этим приращением (до подходящего допуска).

...