Last active: 3 years ago
利用类似洗牌的方式随机打乱数组
let arr = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'];
function shuffle(arr) {
let cac;
let len = arr.length - 1;
let ran;
for (let i = 0; i < len; i++) {
// 保存当前位
cac = arr[i];
// 剩下位的随机抽取
ran = Math.floor(Math.random() * (len - i + 1) + i);
// 将随机抽取的位与当前位替换
arr[i] = arr[ran];
arr[ran] = cac;
}
}
shuffle(arr);
console.log(arr.length);
// arr.sort();