PHP-抢红包算法

看到很多人写,自己也写了个。
大概的主要思路:
比如一个红包20元5个人抢,最小单位为1元。
第一个人抢的范围必须是,1到20-(5-1)*1(因为后面的4个人要考虑到)

<?php
function create($money,$ncount){
    define('MIN_MONEY',0.01);
    $result = array();
    if($money >= $ncount*MIN_MONEY){
        $money *= 100;
        for($i=0; $i<$ncount; $i++){
            if($i === $ncount -1){
                array_push($result,$money);
            }else{
                array_push($result,rand(1,$money-($ncount-$i-1)));    
            }
            
            $money -= $result[$i];
            $result[$i] /= 100;
        }
        shuffle($result);
        return $result;
    }
    return false;
}

$result = create(20,8);
if($result!=false){
    print_r($result);
    echo "\n".'sum:'.array_sum($result);
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容