PHP-抢红包算法

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

= $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);
}

你可能感兴趣的:(PHP-抢红包算法)