文档章节

随机生成红包金额算法

Gavaen
 Gavaen
发布于 2016/12/07 14:18
字数 314
阅读 34
收藏 0
    /**
     * 随机生成红包金额
     * @param $n 红包个数
     * @param $sum  总金额 整数
     * @param $index_max  最大金额在数组中索引
     * @param $error
     * @return array|false
     */
    public static function GenRandRePacketsData($n,$sum,&$index_max,&$error)
    {
        //$n = 20;
        //$sum = 300;
        if($sum < $n)
        {
            $error = '金额总数不能小于红包个数'; //$error = '金额总数必须大于红包个数';
            return false;
        }
        if($n > 50)
        {
            $error = '红包数量不能大于50';
            return false;
        }
        //$sum = $sum * 100;//转为分
        $rst = [];
        $ave = intval($sum/$n);  // 金额除去红包个数 平均值 test:3/3 = 1
        $one_rst = rand(1,$ave); // 随机取1到平均值的数
        $subSum = $one_rst;  // 1
        //$rst[] = $one_rst/100;
        $rst[] = $one_rst; // $rst = ['0'=>1];
        $index_min = 0;
        $index_max = 0;
        $min = $one_rst; // 1
        $max = $one_rst; // 1

        for($i = 2; $i <= $n; $i ++)
        {                   
            $ave = intval(($sum - $subSum)/($n - $i + 1)); // 1
            $one_rst = rand(1,$ave); // 1
            if($min > $one_rst) // 1 > 1
            {
                $min = $one_rst;
                $index_min = $i -1;
            }
            if($max < $one_rst) // 1 < 1
            {
                $max = $one_rst;
                $index_max = $i -1;
            }
            //$rst[] = $one_rst/100;
            $rst[] = $one_rst;
            $subSum += $one_rst; // 1
        }
        $left = $sum - $subSum;

        if($left > 0)
        {
            //$rst[$index_min] = ($rst[$index_min] + $left/100);
            $rst[$index_min] = ($rst[$index_min] + $left);
            if($rst[$index_min] > $max)
            {
                $max = $rst[$index_min];
                $index_max = $index_min;
            }
        }
        //检测重复的最大值处理,确保最大值唯一
        /*for($i =0; $i < $n; $i++)
        {
            if($rst[$i] === $max && $i !== $index_max)
            {
                $one_rst = $rst[$i] -1;
                $rst[$i] = $one_rst;
                $rst[$index_max] = $max + 1;
                break;
            }
        }*/

        //重新乱序
        shuffle($rst);
        //查找最大值
        $index_max = 0;
        $max = $rst[0];
        for($i =1; $i < $n; $i ++)
        {
            if($rst[$i]> $max)
            {
                $index_max = $i;
                $max = $rst[$i];
            }
        }
        return $rst;
    }

 

© 著作权归作者所有

共有 人打赏支持
Gavaen
粉丝 0
博文 6
码字总数 1499
作品 0
杭州
后端工程师
PHP随机红包算法

2017年1月14日 14:19:14 星期六 一, 整体设计 算法有很多种, 可以自行选择, 主要的"架构" 是这样的, 用redis decr()命令去限流, 用mysql去记录各种需要的数据 二, 红包算法 简便起见, 红包金...

大王回山
2017/01/14
0
0
微信红包指定总金额随机生成每个红包金额算法

红包生成算法的需求 预先生成所有的红包还是一个请求随机生成一个红包 简单来说,就是把一个大整数m分解(直接以“分为单位,如1元即100)分解成n个小整数的过程,小整数的范围是[min, max]。...

武当剑客
2015/11/24
1K
1
微信红包的随机算法

有人问过微信的人,大致是这样: public static double getRandomMoney(LeftMoneyPackage _leftMoneyPackage) { // remainSize 剩余的红包数量 // remainMoney 剩余的钱 if (_leftMoneyPack......

背锅侠
2016/02/17
566
0
微信红包的随机算法是怎样实现的?

摘自知乎 ,答案来自:https://www.zhihu.com/question/22625187/answer/85530416 答案来自:https://www.zhihu.com/question/22625187/answer/85530416 有人问过微信的人,大致是这样: 先上...

北极之北
2016/02/23
1K
3
微信公众平台开发(111) 现金红包、裂变红包、企业付款

在这篇微信公众平台开发教程中,我们将介绍如何在实现现金红包、裂变红包、企业付款以及红包交易查询(含现金红包和裂变红包)和企业付款查询的功能。 本文分为以下二个部分: 微信支付接口S...

bengozhong
2016/03/19
220
0

没有更多内容

加载失败,请刷新页面

加载更多

5whys分析法在美团工程师中的实践

前言 网站的质量和稳定性对于用户和公司来说至关重要,但是在网站的快速发展过程中,由于各种原因导致事故不可避免的发生,这些大大小小的事故对公司难免会造成一些负面的影响,为了避免同类...

Skqing
22分钟前
0
0
Android 接收监听开机完成,并且开机自启动

1,定义一个广播接收者的类 ,并重写抽象方法 public class BootCompleteReceiver extends BroadcastReceiver 2,在Androidmanifest 注册 <receiver android:name=".receiver.BootCompleteRece......

lanyu96
26分钟前
1
0
小程序记录

1、button的边框、角等需要在伪元素after修改去除

originDu
28分钟前
0
0
微博什么技术啊……还说支持八个明星并发出轨,结果…

是的,大家可能都知道了,女神张靓颖结婚了。。 我去,写错了,是————赵丽颖。 为什么我头脑一瞬间出现的是张靓颖,作为一个码农,技术宅,拼音缩小都是 ZLY,博主我真有点傻傻分不清楚了...

Java技术栈
28分钟前
3
0
模块化

1,什么是模块化? 模块化是指将一个复杂的系统分解为多个模块,方便编码。 2,为什么要用模块化? 降低复杂性,降低代码耦合度,部署方便,提高效率。 3,模块化的好处? a,避免命名冲突,减少...

羊皮卷
28分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部