如何写一个随机洗牌函数

来源:互联网 发布:apache.exe 编辑:程序博客网 时间:2024/06/05 19:13

看到了很多人写得随机洗牌函数,但是感觉写得都不是太好,自己写了一个试试。

基本要求 给定一定范围的数比如最大值最小值(min.max)在这个之间进行随机洗牌。

首先生成一个按min到最大的max的数组a。

对数组进行循环,每次随机生成一个要取的下标index。

把这个index对应的数num压入新数组b,同时在a中删除这个num。

一直循环只到a中数组不存在元素即可。

JavaScript对应代码

/*

@param (min,max)   min范围的最小值,max范围的最大值

@return (b) 返回的洗牌数组,如果 min,max不存在返回空,如果min<max 抛出错误。

function shuffle(min,max){
var a= [];
var b = [];

       if(Number.isInteger(min)+Number.isInteger(max)<2){

                 return [];

        }

      if(min > max){

           throw new Error("min 不该小于 max");

       }
for(var i = min;i<=max;i++){
a.push(i);
}
console.log(a);
while(a!=0){
var index = Math.floor(Math.random()*a.length);
var number = a.splice(index,1)-0;

   b.push(number);
}
return b;
}



0 0
原创粉丝点击