Javascript: как отсортировать массив для нормальной диаграммы распределения? - PullRequest
0 голосов
/ 23 февраля 2019

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

Пример:

Массив:

[200, 300, 0, 100, 400]

Как это нужно отсортировать:

[0, 100, 200, 300, 400, 300, 200, 100, 0]

Есть идеи, как это сделать в Javascript?

Ответы [ 2 ]

0 голосов
/ 23 февраля 2019

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

var data = [200, 300, 0, 100, 200, 300, 0, 100, 400].sort((a, b) => b - a),
    result = Array
        .from(data.keys())
        .sort((a, b) => b % 2 - a % 2 || (a % 2 ? b - a : a - b))
        .map(i => data[i]);

console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
0 голосов
/ 23 февраля 2019

Вы можете сделать что-то подобное, используя sort, reverse и slice:

const array = [200, 300, 0, 100, 400]
const newArray = [...array.sort((a,b) => a - b), ...array.reverse().slice(1)]

console.log(newArray)
  • array.sort((a,b) => a - b) сортирует массив
  • array.reverse() инвертирует отсортированный массив
  • slice(1) для удаления дубликатамаксимальное значение из обращенного массива

Примечание : Это просто генерирует нормальный распределительный массив из существующего массива путем создания дублирующихся значений по вашему запросу.Но если вы хотите просто преобразовать массив в обычное распределение, без добавления каких-либо элементов, взгляните на @ отличный ответ Нины .

...