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

Javascript
让innerHTML的脚本也可以运行起来
nextSibling
限制复选框的最大可选数
onpropertypchange
让焦点自动跳转
显示、隐藏密码
textarea是否自动换行
鼠标图片振动代码
对联浮动广告效果
一段实时更新的时间代码
让广告代码不再影响你的网页加载速度
载入进度条 效果
二级连动菜单
如何实现浏览器上的右键菜单
html代码调试脚本
表单提交验证类
简单实用的网页表格特效
表单的一些基本用法与技巧
Javascript - HTML的request类
教学演示-UBB,剪贴板,textRange及其他

Javascript教程:随机数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 120 ::
收藏到网摘: 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>

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