initial commit
This commit is contained in:
commit
a8a00f0f49
|
@ -0,0 +1,13 @@
|
|||
(function () {
|
||||
'use strict';
|
||||
|
||||
var shuffle = require('./').knuthShuffle
|
||||
, a = [2,11,37,42]
|
||||
, b
|
||||
;
|
||||
|
||||
// The shuffle modifies the original array
|
||||
// calling a.slice(0) creates a copy, which is assigned to b
|
||||
b = shuffle(a.slice(0));
|
||||
console.log(b);
|
||||
}());
|
|
@ -0,0 +1,29 @@
|
|||
/*jshint -W054 */
|
||||
(function (exports) {
|
||||
'use strict';
|
||||
|
||||
// http://stackoverflow.com/questions/2450954/how-to-randomize-shuffle-a-javascript-array
|
||||
function shuffle(array) {
|
||||
var currentIndex = array.length
|
||||
, temporaryValue
|
||||
, randomIndex
|
||||
;
|
||||
|
||||
// While there remain elements to shuffle...
|
||||
while (0 !== currentIndex) {
|
||||
|
||||
// Pick a remaining element...
|
||||
randomIndex = Math.floor(Math.random() * currentIndex);
|
||||
currentIndex -= 1;
|
||||
|
||||
// And swap it with the current element.
|
||||
temporaryValue = array[currentIndex];
|
||||
array[currentIndex] = array[randomIndex];
|
||||
array[randomIndex] = temporaryValue;
|
||||
}
|
||||
|
||||
return array;
|
||||
}
|
||||
|
||||
exports.knuthShuffle = shuffle;
|
||||
}('undefined' !== typeof exports && exports || new Function('return this')()));
|
|
@ -0,0 +1,32 @@
|
|||
{
|
||||
"name": "knuth-shuffle",
|
||||
"version": "1.0.0",
|
||||
"description": "The Fisher-Yates (aka Knuth) shuffle for Browser and Node.js",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
"test": "node example.js"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git://github.com/coolaj86/knuth-shuffle.git"
|
||||
},
|
||||
"keywords": [
|
||||
"ronald",
|
||||
"fisher",
|
||||
"frank",
|
||||
"yates",
|
||||
"fisher-yates",
|
||||
"donald",
|
||||
"knuth",
|
||||
"shuffle",
|
||||
"random",
|
||||
"randomize",
|
||||
"unbiased",
|
||||
"algorithm"
|
||||
],
|
||||
"author": "AJ ONeal <coolaj86@gmail.com> (http://coolaj86.info/)",
|
||||
"license": "Apache2",
|
||||
"bugs": {
|
||||
"url": "https://github.com/coolaj86/knuth-shuffle/issues"
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue