除了数组拼接之外,有没有什么方法可以用来生成两个数之间的随机数,而不需要重复,直到这两个数之间的所有数都生成了?除了拼接之外,混洗技术或任何其他数组方法都会非常有用。
发布于 2013-05-24 13:46:08
首先,我们使用fisherYates实现(credit goes to @ChristopheD)并扩展数组原型,使其具有可用的随机函数
function arrayShuffle () {
var i = this.length, j, temp;
if ( i === 0 ) return false;
while ( --i ) {
j = Math.floor( Math.random() * ( i + 1 ) );
temp = this[i];
this[i] = this[j];
this[j] = temp;
}
}
Array.prototype.shuffle =arrayShuffle;
var numbers = new Array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
numbers.shuffle();现在,通过使用pop方法,我们从种子中获取一个数字,直到它为空
numbers.pop(); //returns a number为了确保我们有一个由start和end范围内的数字填充的数组,我们使用一个简单的循环来创建种子。
var start = 1;
var end = 5;
var numbers = new Array();
for (var i = start; i <= end; i++) {
numbers.push(i);
}这是一个关于jsfiddle的示例
更新:让fisherYates算法更有效地混洗
发布于 2016-11-22 17:04:15
在处理较小的数组时,我通常会按随机顺序对数组进行排序:
yourArray.sort(function() { return 0.5 - Math.random() });发布于 2013-05-24 13:52:53
尝试此http://jsbin.com/imukuh/1/edit
function randRange(min, max) {
var result = [];
for (var i=min; i<=max; i++) result.push(i);
return result.map(function(v){ return [Math.random(), v] })
.sort().map(function(v){ return v[1] });
}
console.log(randRange(1,5));
// [4, 3, 1, 5, 2]
// [3, 5, 2, 4, 1]
// [1, 5, 2, 3, 4]
// [3, 2, 5, 1, 4]
// ...https://stackoverflow.com/questions/16728297
复制相似问题