PHP拆紅包算法
邏輯比較簡(jiǎn)單,傳入金額.和拆分的數(shù)量
首先循環(huán)要拆分的數(shù)量,判斷如果是最后一個(gè)就把剩下的錢全部塞進(jìn)去;
如果不是,就取剩余的金額(第一次循環(huán)剩余的金額=總金額)除以剩下的次數(shù),取得平均值,然后再隨機(jī)取最小的0.01 和平均值*2,把剩余的金額更新一下就行了。
算法模擬微信拆紅包算法,但是這是提前計(jì)算拆分的數(shù)據(jù)保存的,微信是每次動(dòng)態(tài)計(jì)算的。
代碼如下:
/**
* 拆分紅包
* @param SendRedPackageRequest $request
* @return array
*/
protected function spitMoney(SendRedPackageRequest $request)
{
$result = [];
$reamingMoney = $request->money;
for ($i = $request->count; $i >= 1; $i--) {
if ($i === 1) {
$result[] = round($reamingMoney, 2);
$reamingMoney = 0;
} else {
$average = round(bcdiv($reamingMoney, $i), 2); //平均值
$amount = round(mt_rand(1, $average * 199) / 100, 2);
$reamingMoney = doubleval(bcsub($reamingMoney, $amount));
$result[] = round($amount, 2);
}
}
return $result;
}