Blogger Information
Blog 175
fans 1
comment 0
visits 385816
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
PHP抽奖算法思路
dxp2tq的博客
Original
3385 people have browsed it

大概原理是:
1,生成一个随机数;
2,循环对比第N个奖品的概率;
3,确定奖品;

如果按照这个算法,主观上是抽一次奖,但客观上,把每个奖品都循环抽了一遍,其实是抽了N次,不知道我的理解对不对。

下面是我写的算法,具体原理是:
1,先确定随机数(幸运号码)的范围;
2,确定每个奖品的号码区间,确保只抽一次奖能对应到某个奖品;
3,根据范围生成一个幸运号码;
4,根据范围确定奖品;

请教各路大神,有没有更优的算法或思路?

**********************************************************************************

$goods = [
           0 => [
               'id'    => 1,
               'name'  => '苹果电脑',
               'odds'  => '0.01' //概率
           ],
           1 => [
               'id'    => 2,
               'name'  => 'Iphone',
               'odds'  => '10.99'
           ],
           2 => [
               'id'    => 3,
               'name'  => '200元红包',
               'odds'  => '19'
           ],
           3 => [
               'id'    => 4,
               'name'  => '安慰奖',
               'odds'  => '30'
           ],
           4 => [
               'id'    => 5,
               'name'  => '什么都没抽到',
               'odds'  => '40'
           ],
       ];


       $baseOdds = 100; //抽奖概率基数,默认100%
       $maxBase = 1; //抽奖概率基数倍数,默认1,如果奖品概率有小数位,该倍数为10的小数位数平方,具体看下面

       foreach ($goods as $good) {
           $decimal = strpbrk($good['odds'], '.'); //获取小数点后面的内容
           if ($decimal !== false) {
               $decimalCount = strlen($decimal) - 1;//获取小数点后面的位数
               $newMaxBase = pow(10, $decimalCount); //例如概率如果是0.01,则全局的抽奖概率基数需要以10的平方倍数上涨
               if ($newMaxBase > $maxBase) {
                   $maxBase = $newMaxBase; //更新基数倍数
               }
           }
       }
       $baseOdds = $maxBase ? $baseOdds * $maxBase : $baseOdds; //更新概率基数

       $start = 1;
       $end = 0;
       $luckyCompare = $tickets = [];
       //为每个奖品生成一个幸运数区间
       foreach ($goods as $key => $good) {
           $newOdds = $good['odds'] * $maxBase;
           $end = $end + $newOdds;
           $luckyCompare[$good['id']] = [$start, $end];
           $tick = mt_rand($start, $end);
           $start = $start + $newOdds;
           $tickets[$good['id']] = $tick;
       }
       $luckyNumber = mt_rand(1, $baseOdds);
       var_dump($luckyNumber);
       var_dump($luckyCompare);
       foreach ($luckyCompare as $goodId => $compare) {
           if ($compare[0] <= $luckyNumber && $compare[1] >= $luckyNumber) {
               $luckyGood = $goodId; //最终的奖品
               break;
           }
       }

       var_dump($luckyGood);

链接来源:

https://segmentfault.com/q/1010000006059529/revision

如有侵权,联系本人删除!谢谢分享!



Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post