javascript中两个限制之间的随机非重复数生成

时间:2013-05-24 05:37:50

标签: javascript

除了数组拼接之外,还有什么方法可以用来在两个数字之间生成一个随机数而不重复,直到生成了这两个数字之间的所有数字?除了拼接之外,改组技术或任何其他阵列方法都非常有用。

3 个答案:

答案 0 :(得分:2)

首先我们使用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

为了确保我们的数组中包含startend范围内的数字,我们使用一个简单的循环来创建种子。

var start = 1;
var end = 5;
var numbers = new Array();
for (var i = start; i <= end; i++) {
    numbers.push(i);
}

这是jsfiddle

上的示例

更新:让渔民改变洗牌更有效率

答案 1 :(得分:0)

处理较小数组时我通常做的是随机排序数组:

yourArray.sort(function() { return 0.5 - Math.random() });

答案 2 :(得分:-1)

试试这个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]
// ...