当前位置: 首页 > 图文教程 > 网络编程 > Javascript > Javascript教程:随机数

Javascript
jquery 交替为表格添加样式的代码
jquery下操作HTML控件的实现代码
JQuery获取元素文档大小、偏移和位置和滚动条位置的方法集合
海量经典的jQuery插件集合
JavaScript获取鼠标坐标的函数(兼容IE、FireFox、Chrome)
JavaScript关于select的相关操作说明
jQuery的一些特性和用法整理小结
用jQuery扩展自写的 UI导航
JQuery 引发两次$(document.ready)事件
javascript实现的基于金山词霸网络翻译的代码
Span元素的width属性无效果原因及解决方案
javascript 不间断的图片滚动并可点击
利用onresize使得div可以随着屏幕大小而自适应的代码
extjs 为某个事件设置拦截器
javascript 构建一个xmlhttp对象池合理创建和使用xmlhttp对象
javascript 特性检测并非浏览器检测
20个非常有用的PHP类库 加速php开发
前淘宝前端开发工程师阿当的PPT中有JS技术理念问题
AJAX的跨域与JSONP(为文章自动添加短址的功能)
JavaScript学习笔记(十)

Javascript教程:随机数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 116 ::
收藏到网摘: n/a

弄个随机数的东西,直接从网上找了一个现成的,简单看了两眼,感觉算法应该是对的,但今天测试下来,是不对的;

网上大多数人用的写法是这样的:

function getRandomA(rMin,rMax) {
    var range = rMax - rMin;
 var r = rMin + Math.round( Math.random() * range);
    return r;
}

用十万的量跑了一下才发现,首位和末位随机的机率不高;

测试一下:

<script>
//A
function getRandomA(rMin,rMax) {
    var range = rMax - rMin;
 var r = rMin + Math.round( Math.random() * range);
    return r;
}
//test code.
var randArray = new Array();
var testNume = 100000;
for(var y=0; y<testNume; y++){
    var r = getRandomA(0,9);
 if(typeof(randArray[r]) == 'undefined') randArray[r] = 1;
    else randArray[r] = randArray[r] + 1;
}
for(var y=0; y<randArray.length; y++){
 document.write('第一种写法,数字' + y + '共命中:' + randArray[y] + '次' + '<br \/>');
}
</script>

从网上找了找发现大家都是这样写的,但这样应该是有问题的。

于是我自已写了一个,简单验证了一下,应该是可以的,很平均。

function getRandom(rMin,rMax) {
 if(rMin == 0) rMax++;
 return Math.floor(rMax*Math.random() + rMin);
}

 HTML代码

<script>//B
function getRandom(rMin,rMax) {
 if(rMin == 0) rMax++;
 return Math.floor(rMax*Math.random() + rMin);
}
//test code.
var randArray = new Array();
var testNume = 100000;
for(var y=0; y<testNume; y++){
    var r = getRandom(0,9);
 if(typeof(randArray[r]) == 'undefined') randArray[r] = 1;
    else randArray[r] = randArray[r] + 1;
}
for(var y=0; y<randArray.length; y++){
 document.write('我自已的写法,数字' + y + '共命中:' + randArray[y] + '次' + '<br \/>');
}
</script>

在这里记录给自已,这个应该还比较常用,看来大家都在用的东西不一定就靠谱,多质疑一下还是有好处的。