美文网首页
PHP随机红包算法

PHP随机红包算法

作者: 打工是不可能打工的1 | 来源:发表于2020-07-14 15:42 被阅读0次

随机红包算法就是给定一个具体的红包金额,具体的红包个数,还有给定红包的最大金额和最小金额,按照业务可以分成两种,一种是预先生成,一种是实时生成

1、预先生成

public function getBonus($money, $num, $min, $max) //$num是总的红包数量
    {
        $data = array();
        if ($min * $num > $money) {
            return array();
        }
        if ($max * $num < $money) {
            return array();
        }
        while ($num >= 1) {
            $num--;
            $kmix = max($min, $money - $num * $max);
            $kmax = min($max, $money - $num * $min);
            $kAvg = $money / ($num + 1);
            //获取最大值和最小值的距离之间的最小值
            $kDis = min($kAvg - $kmix, $kmax - $kAvg);
            //获取0到1之间的随机数与距离最小值相乘得出浮动区间,这使得浮动区间不会超出范围
            $r = ((float)(rand(1, 10000) / 10000) - 0.5) * $kDis * 2;
            $k = round($kAvg + $r, 2);
            $money -= $k;
            $data[] = $k;
        }
        return $data;
    }

2、实时生成

 public function getBonus($money, $num, $min, $max)  //$num是剩余红包数量
    {
        $num-=1;
        if ($num * $min >= $money) {
            throw new \Exception('最小金额超出范围');
        }
        if ($num * $max <= $money) {
            throw new \Exception('最大金额太小');
        }
        $kmix = max($min, $money - $num * $max); //最小金额
        $kmax = min($max, $money - $num * $min); //最大金额

        $kAvg = $money / ($num + 1);
        //获取最大值和最小值的距离之间的最小值
        $kDis = min($kAvg - $kmix, $kmax - $kAvg);
        //获取0到1之间的随机数与距离最小值相乘得出浮动区间,这使得浮动区间不会超出范围
        $r = ((float)(rand(1, 10000) / 10000) - 0.5) * $kDis * 2;
        $k = round($kAvg + $r, 2);
        return $k;
    }

相关文章

  • 2018-12-21php红包分发算法

  • PHP随机红包算法

    随机红包算法就是给定一个具体的红包金额,具体的红包个数,还有给定红包的最大金额和最小金额,按照业务可以分成两种,一...

  • PHP随机红包

  • PHP最简单的随机红包算法

    需求: 5000元,随机分给10000人,要求每个人最少0.01,最大50; 分析: 5000元分给10000人,...

  • PHP随机红包算法(含最小值)

    首先要保底,每个人要拿到一个最低的钱,那么要均分的钱=总钱数-人数*最低金额,lcg_value()这个函数取 0...

  • 抢红包算法@随机算法

    生成随机数 注:randomElement() 如果 range 是空,返回 nil 数组随机 洗牌算法 Swif...

  • PHP红包算法

    代码 输出1 array(6) {[0]=>float(5544)[1]=>float(1805)[2]=>flo...

  • 随机红包分配算法

    红包随机分配的入参,一般只有两个,总金额与抢红包的总人数。难点是要保证在最后一个人抢完之前,不能让剩余钱包为空。所...

  • 微信红包随机算法初探

    本文简书备份地址:微信红包随机算法初探 最近看了一篇文章,讲微信红包随机算法的。感觉很不错,所以自己实现了下,并进...

  • Golang洗牌算法,抢红包算法

    本文为转载,原文:Golang洗牌算法,抢红包算法 1. 洗牌算法 洗牌算法,即将原来的顺序打乱,组成新的随机排序...

网友评论

      本文标题:PHP随机红包算法

      本文链接:https://www.haomeiwen.com/subject/jrqacktx.html