测试例$ar = array(1 => 1000, 2 => 300000, 3 => 300000); //奖池
while(array_sum($ar)) {
$n = get_rand($ar); //得到奖项级别,可打印出来看看分布情况
@$res[$n]++;
}
print_r($res);//看看中奖分布
print_r($ar); //看看奖池是否有剩余function get_rand(&$proArr) {
$proSum = array_sum($proArr);
$randNum = mt_rand(1, $proSum);
foreach($proArr as $key => $proCur) {
$proSum -= $proCur;
if($randNum > $proSum) {
$proArr[$key]--; //从奖池里扣除
return $key;
}
}
}
Array
(
[2] => 300000
[3] => 300000
[1] => 1000
)
Array
(
[1] => 0
[2] => 0
[3] => 0
)实用时,你需要保存奖池的变化,以供下一次抽奖使用
while(array_sum($ar)) {
$n = get_rand($ar); //得到奖项级别,可打印出来看看分布情况
@$res[$n]++;
}
print_r($res);//看看中奖分布
print_r($ar); //看看奖池是否有剩余function get_rand(&$proArr) {
$proSum = array_sum($proArr);
$randNum = mt_rand(1, $proSum);
foreach($proArr as $key => $proCur) {
$proSum -= $proCur;
if($randNum > $proSum) {
$proArr[$key]--; //从奖池里扣除
return $key;
}
}
}
Array
(
[2] => 300000
[3] => 300000
[1] => 1000
)
Array
(
[1] => 0
[2] => 0
[3] => 0
)实用时,你需要保存奖池的变化,以供下一次抽奖使用
每次使用sql的随机语句抽出一个中奖状态为0的用户,然后更新即可
for($i=0; $i<10000; $i++) { //抽奖1万次
$n = get_rand($ar); //得到奖项级别,可打印出来看看分布情况
@$res[$n]++;
}
print_r($res);//看看中奖分布function get_rand(&$proArr) {
$proSum = array_sum($proArr);
$randNum = mt_rand(1, $proSum);
foreach($proArr as $key => $proCur) {
$proSum -= $proCur;
if($randNum > $proSum) {
//$proArr[$key]--; //从奖池里扣除 因为是概率抽奖,这一句就不要了
return $key;
}
}
}
可能的结果Array
(
[3] => 5955
[2] => 3059
[1] => 986
)