Трудно выразить словами, но я ищу функцию, которая берет массив и уменьшает его до заданного размера. Вариант использования указывает тики для графика в d3.
const availableDatetimes: Date[] = [...]
const numberOfXTicks = chartWidth / 80
const tickValues = reduceArrSize(availableDatetimes, numberOfXTicks)
результат должен иметь равномерно распределенные даты
@kellys да ... нужно поддерживать равномерное распределение. Предположим, что значения в массиве изначально равномерно распределены
Я назвал это shrinkArray()
, потому что сокращение массива — это название другой четко определенной операции. Вот:
const shrinkArray = (array, size) => {
const step = array.length / size
return array.filter((v, i) => Math.floor(i % step) == 0)
}
Давайте сократим массив размером 100 до размера 33:
const originalArray = (new Array(100).fill(0)).map((v, i) => i)
const shrunkenArray = shrinkArray(originalArray, 33)
console.info(shrunkenArray);
console.info(shrunkenArray.length == 33);
Так:
[
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11,
12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23,
24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35,
36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47,
48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59,
60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71,
72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83,
84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95,
96, 97, 98, 99
]
сокращается до:
[
0, 4, 7, 10, 13, 16, 19, 22, 25,
28, 31, 34, 37, 40, 43, 46, 49, 53,
56, 59, 62, 65, 68, 71, 74, 77, 80,
83, 86, 89, 92, 95, 98
]
это размер 33.
В этом примере массив представляет собой целые числа от 0 до 99, но очевидно, что функция работает для любого типа данных.
Вы также можете добавить `if (array.length <= size) return array;` в качестве первой строки функции, так как в этом случае нет необходимости фильтровать. Хотя и без этой строки он работает так же, это просто напрасные вычисления.
стоит ли добавить Math.floor в расчет шага так и есть const step = Math.floor(array.length / size)
. в любом случае я приму это, так как это почти то же самое, что я использовал. благодарю вас
@JoeyGough Нет, если вы добавите это, нет гарантии, что вы получите именно тот размер, который вам нужен. Например, если длина массива равна 100, и вы хотите уменьшить его до 30, у вас будет step = Math.floor(100/30) = 3
, что даст вам массив размером 34.
Итак, как он должен уменьшить размер? Удалить некоторые даты?