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 $proCur) {   
        $randNum = mt_rand(1, $proSum);  //返回随机整数
         if ($randNum <= $proCur) {   
          $result = $key;   
          break;   
        } else {   
          $proSum -= $proCur;   
        }   
      }   
      unset ($proArr);   
      return $result;   
    }

上述内容就是PHP中怎么实现一个大转盘抽奖算法,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


本文名称:PHP中怎么实现一个大转盘抽奖算法
浏览路径:http://scyanting.com/article/geihce.html