首頁  >  文章  >  後端開發  >  簡析PHP拆紅包演算法

簡析PHP拆紅包演算法

藏色散人
藏色散人轉載
2021-06-09 15:02:024540瀏覽

這篇文章給大家簡析PHP拆紅包演算法,有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

PHP拆紅包演算法

#程式碼如下:

/**
     * 拆分红包
     * @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;
    }

邏輯比較簡單,傳入金額.和分割的數量

先循環要拆分的數量,判斷如果是最後一個就把剩下的錢全部塞進去;

如果不是,就取剩餘的金額(第一次循環剩餘的金額=總金額)除以剩下的次數,取得平均值,然後再隨機取最小的0.01 和平均值*2,把剩餘的金額更新一下就行了。

演算法模擬微信拆紅包演算法,但是這是提前計算拆分的資料保存的,微信是每次動態計算的。

推薦學習:《PHP影片教學

以上是簡析PHP拆紅包演算法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:learnku.com。如有侵權,請聯絡admin@php.cn刪除