话不多说,直接上代码
function get_rand($proArr) {
$result = '';
//概率数组的总概率精度
$proSum = array_sum($proArr);
//概率数组循环
foreach ($proArr as $key => $proCur) {
$randNum = mt_rand(1, $proSum);
if ($randNum <= $proCur) {
$result = $key;
break;
} else {
$proSum -= $proCur;
}
}
unset ($proArr);
return $result;
}
上述代码是一段经典的概率算法,$proArr是一个预先设置的数组,假设数组为:array(1,5,10,12,22,55),开始是从1,100这个概率范围内筛选第一个数是否在他的出现概率范围之内, 如果不在,则将概率空间,也就是k的值减去刚刚的那个数字的概率空间,在本例当中就是减去100,也就是说第二个数是在1,99这个范围内筛选的。这样筛选到最终,总会有一个数满足要求。就相当于去一个箱子里摸东西,第一个不是,第二个不是,第三个还不是,那最后一个一定是。这个算法简单,而且效率非常高。这个$proArr 怎么获得呢?
$prize_arr = array(
'0' => array('id'=>1,'prize'=>'一等奖','v'=>1),
'1' => array('id'=>2,'prize'=>'二等奖','v'=>5),
'2' => array('id'=>3,'prize'=>'三等奖','v'=>10),
'3' => array('id'=>4,'prize'=>'四等奖','v'=>12),
'4' => array('id'=>5,'prize'=>'五等奖','v'=>22),
'5' => array('id'=>6,'prize'=>'很遗憾下次好运','v'=>50),
);
foreach ($prize_arr as $key => $val) {
$proArr[$val['id']] = $val['v'];
}
通过以上方法就能根据概率获取到一次的奖项了