$arr = array(
array('id'=>1,'name'=>'特等奖','v'=>50),
array('id'=>2,'name'=>'一等奖','v'=>20),
array('id'=>3,'name'=>'二等奖','v'=>20),
array('id'=>6,'name'=>'没中奖','v'=>10)
);
这有一个预设的奖品 但是现在的需求是 v越大中奖的概率越低 越小的中奖概率越大 更网上很多代码都不符合 求大神帮忙下 有红包酬谢
目前的算法为 v越大中奖概率越大 求大神帮忙:
private function getRand($proArr)
{
$result = array();
$arr = [];
foreach ($proArr as $key => $val) {
$arr[$key] = $val['v'];
}
// 概率数组的总概率
$proSum = array_sum($arr);
asort($arr);
// 概率数组循环
foreach ($arr as $k => $v) {
$randNum = mt_rand(1, $proSum);
if ($randNum <= $v) {
$result = $proArr[$k];
break;
} else {
$proSum -= $v;
}
}
return $result;
}
先把所有v的倒数求和 s=∑(1/v)
然后每个中奖的概率按1/(v*s)算就好了