$prizeList = [1=>["id"=>1,"name"=>'A',"chance"=>50],2=>["id"=>2,"name"=>'B',"chance"=>80],3=>["id"=>3,"name"=>'C',"chance"=>70]];
$arr = [1=>50,2=>80,3=>70];
$prize_id = get_rand($arr); //根据概率获取奖项id
function get_rand($proArr) {
$result = '';
//概率数组的总概率精度
$proSum = array_sum($proArr);
//概率数组循环
$randNum = mt_rand(1, $proSum);
$temp = 0;
foreach ($proArr as $key => $proCur) {
if ($randNum <= ($proCur+$temp)) {
$result = $key;
break;
}
else $temp +=$proCur;
}
unset ($proArr);
return $result;
}
九宫格抽奖概率算法
最新推荐文章于 2023-04-14 14:12:11 发布
本文介绍了一种基于概率权重实现的抽奖算法。通过定义奖项及其对应的中奖概率,使用PHP语言实现了从奖项池中按概率抽取奖项的功能。该算法首先计算所有奖项概率之和,然后生成一个介于1到总概率之间的随机数,最后遍历奖项池,找到第一个累计概率大于等于随机数的奖项作为中奖结果。

1216

被折叠的 条评论
为什么被折叠?



