抽獎,機率不變化:php
經典的機率算法函數:以下前端
/*
* 經典的機率算法,
* $proArr是一個預先設置的數組,
* 假設數組爲:array(20,30,50),
* 開始是從1,100 這個機率範圍內篩選第一個數是否在他的出現機率範圍以內,
* 若是不在,機率變成100-20=80,
* 就至關於去一個箱子裏摸東西,
* 第一個不是,第二個不是,第三個還不是,那最後一個必定是。
* 這樣 篩選到最終,總會有一個數知足要求。
* 這個算法在大數據量的項目中效率很是棒。
*/
function
get_rand(
$proArr
) {
//機率數組的總機率精度
$proSum
=
array_sum
(
$proArr
);
//機率數組循環
foreach
(
$proArr
as
$key
=>
$proCur
) {
$randNum
= mt_rand(1,
$proSum
);
if
(
$randNum
<=
$proCur
) {
$result
=
$key
; //得到獎品的ID
break
;
}
else
{
$proSum
-=
$proCur
;
}
}
unset (
$proArr
);
return
$result
;
}
/*
* 獎項數組
* 是一個二維數組,記錄了全部本次抽獎的獎項信息,
* 其中id表示中獎等級,prize表示獎品,v表示中獎機率。
* 注意其中的v必須爲整數,你能夠將對應的 獎項的v設置成0,即意味着該獎項抽中的概率是0,
* 數組中v的總和(基數),基數越大越能體現機率的準確性。
* 本例中v的總和爲100,那麼平板電腦對應的 中獎機率就是1%,
* 若是v的總和是10000,那中獎機率就是萬分之一了。
*
*/
$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'
=>
'4G優盤'
,
'v'
=>12),
'4'
=>
array
(
'id'
=>5,
'prize'
=>
'10Q幣'
,
'v'
=>22),
'5'
=>
array
(
'id'
=>6,
'prize'
=>
'下次沒準就能中哦'
,
'v'
=>50),
);
/*
* 每次前端頁面的請求,PHP循環獎項設置數組,
* 經過幾率計算函數get_rand獲取抽中的獎項id。
* 將中獎獎品保存在數組$res['yes']中,
* 而剩下的未中獎的信息保存在$res['no']中,
* 最後輸出json格式數據給前端頁面。
*/
foreach
(
$prize_arr
as
$key
=>
$val
) {
$arr
[
$val
[
'id'
]] =
$val
[
'v'
]; //這裏$arr的‘id’是從1開始的哦。
}
$rid
= get_rand(
$arr
);
//根據機率獲取獎項id
$res
[
'yes'
] =
$prize_arr
[
$rid
-1][
'prize'
];
//中獎項
unset(
$prize_arr
[
$rid
-1]);
//將中獎項從數組中剔除,剩下未中獎項,這一步和下一步具體看獎品數量是否爲1,是1則刪除而且打亂順序
shuffle(
$prize_arr
);
//打亂數組順序
for
(
$i
=0;
$i
<
count
(
$prize_arr
);
$i
++){
$pr
[] =
$prize_arr
[
$i
][
'prize'
];
}
$res
[
'no'
] =
$pr
;
?>