var qz=0;//权重总数
var num=[[1,5,3,10],[2,6],[3,7],[4,2],[5,4],[6,11],[7,1],[8,30],[9,23,24],[10,40,44,43,53]];//[权重,数值,(数值,...)]
function qsj(num){
var i;
if(qz==0)
//计算权重总数,也是权重随机数的产生范围
for(i=0;i
//产生权重随机数
var n=parseInt(Math.random()*(qz-1))+1;
for (i=1;n>0;i++){n-=i;}
return(i-1);
}
//测试数据
var re=[0,0,0,0,0,0,0,0,0,0];//记录各权重出现的次数
var j=0,k=0;
for(k=0;k<10;k++){
for(j=0;j<10000;j++){
var i=qsj(num);
re[i-1]++;
}
for(j=0;jdocument.write("
");
re=[0,0,0,0,0,0,0,0,0,0];
}
//调用
/**
function dy(){
var x=qsj(num);
if(num[x-1].length>2){//在相同权重的数里选出一个
var i=parseInt(Math.random()*(num[x-1].length-1))+1;
return(num[x-1][i]);
}else{return(num[x-1][1]);}
}
document.write(dy());
*/
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7944812/viewspace-1017917/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/7944812/viewspace-1017917/