php生成红包

<?php
    /**
     * 随机生成红包金额
     * @param $n 红包个数
     * @param $sum  总金额 整数
     * @param $index_max  最大金额在数组中索引
     * @param $error
     * @return array|false
     */
    public static function GenRandRePacketsData($n,$sum,&$index_max,&$error)
    {
        if($sum < $n)
        {
            $error = '金额总数不能小于红包个数'; //金额总数必须大于红包个数;
            return false;
        }
        if($n > 50)
        {
            $error = '红包数量不能大于50';
            return false;
        }
        //$sum = $sum * 100;//转为分
        $rst = [];
        $ave = intval($sum/$n);  // 金额除去红包个数 平均值
        $one_rst = rand(1,$ave); // 随机取1到平均值的数
        $subSum = $one_rst;  
        $rst[] = $one_rst; 
        $index_min = 0;
        $index_max = 0;
        $min = $one_rst; 
        $max = $one_rst; 

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

        if($left > 0)
        {
            $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;
    }

  

posted on 2016-11-10 15:31  diguaer  阅读(201)  评论(0编辑  收藏  举报

导航