PHP概率计算函数汇总
其实发这篇博感觉并没有什么用,太简单了,会的人不屑看,不会的人自已动动脑子也想到了。但是看着自已的博客已经这么久没更,真心疼~。粗略算下一篇只有代码的水文,会占用OSC至少十几KB的数据库空间呢,但是,一想到乱弹里的然并卵,也就释然了。 /**
function __construct($initdata = array()){ function addData($name,$chance){ function getOne(){ /**
这是一个很经典的概率算法函数: $proCur) {
$randNum = mt_rand(1,$proSum); //抽取随机数
if ($randNum <= $proCur) {
$result = $key; //得出结果
break;
} else {
$proSum -= $proCur;
}
}
unset ($proArr);
return $result;
}
假设:我们有这样一个数组:a奖概率20%,b奖概率30%,c奖概率50% 20,'b'=>30,'c'=>50);
模拟函数执行过程: 总概率精度为20+30+50=100 第一次数组循环,$procur=20 假设抽取的随机数rand(1,100),假设抽到$randNum=55 if判断------- 如果$randNum<=20,则result=a 否则进入下一循环,总概率精度变为100-20=80 第二次数组循环,$procur=30 假设抽取的随机数rand(1,80),假设抽到$randNum=33 if判断--------- 如果$randNum<=30,则result=b 否则进入下一循环,总概率精度变为80-30=50 第三次数组循环,$prosur=50; 假设抽取的随机数rand(1,50),不管怎么抽,随机数都会<或=50, 那么得出result=c; 因为样本没有改变,虽然可能抽取的随机数不止一个,但是概率是不变的。 或者也可以这样: $val)
{
if($rand_num<=$val+$tmp_num)
{
$n=$k;
break;
}else
{
$tmp_num+=$val;
}
}
return $n;
}
在给大家分享一个抽奖的概率算法 $proCur) {
$randNum = mt_rand(1,$proSum);
if ($randNum <= $proCur) {
$result = $key;
break;
} else {
$proSum -= $proCur;
}
}
unset ($proArr);
return $result;
}
/*
/*
$res['yes'] = $prize_arr[$rid-1]['prize']; //中奖项 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |