在工作中常常会用到数组,按照某种规律生成数组很常见,前两天在社区看到洗牌,就思考了一下,能不能用数组来模仿洗牌。主要是两部分,一、是数组的生成,这个都不难。二、是数组的随机排列。
数组生成和数组的随机排列,我想到了两个方法,第一个方法是大家经常见的,用循环,第二种是用数组自有的方法,效率更高,推荐使用第二个
数组生成方法一
/*生成数组 方法一 @param len数组长度 @param items屏蔽元素,数组 */ function makeArray(len,items){ var arr = []; for(var i = 0; i < len; i++){ arr.push(i); } for(var j = 0, l = items.length; j < l; j++){ console.log(arr.splice((items[j]), 1)); } console.dir(arr); return arr; }
数组生成方法二:
function makeArr(len,items){ var arr = new Array(len + 1); var result = arr.join('0').split('').map(function(item, index){return index;}); for(var j = 0, l = items.length ; j < l; j++){ console.log(result.splice((items[j]), 1)); } return result; }
数组随机排列方法一:
/*数组洗牌 */ function shuffle(arr){ for(var i = arr.length - 1; i; i--){ var temp, random = parseInt(Math.random() * i); temp = arr[i]; arr[i] = arr[random]; arr[random] = temp; } console.dir(arr); return arr; }
数组随机排列方法二:
function arrShuffle(arr){ var result = arr.sort(function(){ return Math.random() > 0.5; }); return result; }
demo在我的github上:https://github.com/chenkehxx/practice/blob/test/arr_shuffle.html