获取不重复的随机数

来自脚本之家

var count=3000; 
var original=new Array;   //原始数组 

//给原始数组original赋值 
for (var i=0;i<count;i++){ 
    original[i]=i+1; 
} 
original.sort(function(){ return 0.5 - Math.random(); }); 
for (var i=0;i<count;i++){ 
console.log(original[i]+"  "); 
} 

JavaScript的Math对象提供了random()方法,可以获取一个[0,1)的随机数,利用这个方法,取一个随机数容易,但要是取一个随机并且不重复的数,就需要绕点弯子

试着更换一下思路,获取随机数并不一定需要随机取得一个值,并前后判断是否重复,可以首先创建一个范围,并以该范围所有的值创建一个数组,将数组的排序随机,那么从该数组中按线性获取的值,不也就是随机不定的吗

且由于只是重新排列了数组,数组中永远不会出现重复的值,只需利用Array的sort()方法和Math.random()方法就可以实现获取随机不重复的功能

sort()方法:sort()用于数组,如果不传入参数,那么它会对数组的每一项调用toString()方法,再对每一个字符串进行比较排序(按照首字符的编码大小排序)

若传入参数,会按照参数的正负情况对每两个进行该方法的数组项排序。

无参的方法调用在升降排序number类型数据时并不好用,所以一般给sort()方法传入一个“比较”函数,以此为number类型的数组项升降排序

利用该方法的排序特性,随机这种排序就可以达到随机打乱数组的效果

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容