php 打乱数组顺序_PHP实现大转盘抽奖算法

b6b7df67088635bc9796290811457b47.png

php中文网最新课程

每日17点准时技术干货分享

b00844517574cbe1d6c5fdc54b9ddb74.png

4a5052e07efc763947f9da6266295a46.gif

本文通过具体的实例向大家介绍了PHP语言实现大转盘抽奖算法,希望对大家学习PHP抽奖有所帮助。

流程:

1.拼装奖项数组;

2.计算概率;

3.返回中奖情况。

代码如下:中奖概率 ' v ' 可以在后台设置,传到此方法中,注意传整数

function get_gift(){          //拼装奖项数组        // 奖项id,奖品,概率        $prize_arr = array(             '0' => array('id'=>1,'prize'=>'平板电脑','v'=>0),             '1' => array('id'=>2,'prize'=>'数码相机','v'=>0),             '2' => array('id'=>3,'prize'=>'音箱设备','v'=>0),             '3' => array('id'=>4,'prize'=>'4G优盘','v'=>5),             '4' => array('id'=>5,'prize'=>'10Q币','v'=>0),             '5' => array('id'=>6,'prize'=>'空奖','v'=>5),           );            foreach ($prize_arr as $key => $val) {             $arr[$val['id']] = $val['v'];//概率数组           }            $rid = $this->get_rand($arr); //根据概率获取奖项id           $res['yes'] = $prize_arr[$rid-1]['prize']; //中奖项           unset($prize_arr[$rid-1]); //将中奖项从数组中剔除,剩下未中奖项           shuffle($prize_arr); //打乱数组顺序           for($i=0;$i          $pr[] = $prize_arr[$i]['prize'];  //未中奖项数组         }           $res['no'] = $pr;        // var_dump($res);         if($res['yes']!='空奖'){              $result['status']=1;              $result['name']=$res['yes'];          }else{              $result['status']=-1;              $result['msg']=$res['yes'];          }           //return $result;          var_dump($result);    }       //计算中奖概率    function get_rand($proArr) {         $result = '';          //概率数组的总概率精度         $proSum = array_sum($proArr);         // var_dump($proSum);       //概率数组循环         foreach ($proArr as $key => $proCur) {           $randNum = mt_rand(1, $proSum);  //返回随机整数         if ($randNum <= $proCur) {             $result = $key;             break;           } else {             $proSum -= $proCur;           }         }         unset ($proArr);         return $result;       }

efd51a6491e20167a24ec1b406e90f28.png

9fdebb0231650adf3dcc2026f0e6474e.png

2f0c028b47f1033340aa4832270a0466.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值