UNPKG

@extra-array/permutation-update

Version:

Picks an arbitrary permutation.

26 lines (25 loc) 686 B
'use strict'; function random(r) { var a = Math.floor(r * 2 ** 31); return function () { var t = a += 0x6D2B79F5; t = Math.imul(t ^ t >>> 15, t | 1); t ^= t + Math.imul(t ^ t >>> 7, t | 61); return ((t ^ t >>> 14) >>> 0) / 4294967296; }; } function permutation$(x, n = -1, r = Math.random()) { if (n > x.length) return x; var X = x.length, rnd = random(r); var n = n >= 0 ? n : Math.floor((X + 1) * rnd()); for (var i = 0; i < n; i++) { var j = i + Math.floor((X - i) * rnd()); var t = x[i]; x[i] = x[j]; x[j] = t; } x.length = n; return x; } module.exports = permutation$;