js洗牌算法实现产生随机数组

在学习排序算法的时候,经常要用到随机数组,于是就写了一个生成随机数组的方法。算法来自网络,只是修改成了 JavaScript 版本。

基本原理是洗牌算法,首先从所有元素中随机选取一个与第一个元素进行交换,然后在第二个之后选择一个元素与第二个交换,直到最后一个元素。这样能确保每个元素在每个位置的概率都是1/n。

具体代码如下:

 
      
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
 
      
/**
*
* 生成从 1 到 length 之间的随机数组
*
* @length 随机数组的长度,如果未传递该参数,那么 length 为默认值 9
*
*/
function randomArray(length) {
var i,
index,
temp,
arr = [length];
length = typeof(length) === 'undefined' ? 9 : length;
for (i = 1; i <= length; i++) {
arr[i - 1] = i;
}
// 打乱数组
for (i = 1; i <= length; i++) {
// 产生从 i 到 length 之间的随机数
index = parseInt( Math.random() * (length - i)) + i;
if (index != i) {
temp = arr[i];
arr[i] = arr[index];
arr[index] = temp;
}
}
return arr;
}

你可能感兴趣的:(js,算法思想,前端技术)