775 B
775 B
title, tags, firstSeen, lastUpdated
| title | tags | firstSeen | lastUpdated |
|---|---|---|---|
| sampleSize | array,random,intermediate | 2017-12-31T13:56:28+02:00 | 2020-10-22T20:24:30+03:00 |
Gets n random elements at unique keys from an array up to the size of the array.
- Shuffle the array using the Fisher-Yates algorithm.
- Use
Array.prototype.slice()to get the firstnelements. - Omit the second argument,
n, to get only one element at random from the array.
const sampleSize = ([...arr], n = 1) => {
let m = arr.length;
while (m) {
const i = Math.floor(Math.random() * m--);
[arr[m], arr[i]] = [arr[i], arr[m]];
}
return arr.slice(0, n);
};
sampleSize([1, 2, 3], 2); // [3, 1]
sampleSize([1, 2, 3], 4); // [2, 3, 1]