zoukankan      html  css  js  c++  java
  • PHP实现大转盘抽奖算法实例

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

    流程:
    1.拼装奖项数组,2.计算概率,3.返回中奖情况

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

     1 function get_gift(){  
     2         //拼装奖项数组
     3         // 奖项id,奖品,概率
     4         $prize_arr = array(   
     5           '0' => array('id'=>1,'prize'=>'平板电脑','v'=>0),   
     6           '1' => array('id'=>2,'prize'=>'数码相机','v'=>0),   
     7           '2' => array('id'=>3,'prize'=>'音箱设备','v'=>0),   
     8           '3' => array('id'=>4,'prize'=>'4G优盘','v'=>5),   
     9           '4' => array('id'=>5,'prize'=>'10Q币','v'=>0),   
    10           '5' => array('id'=>6,'prize'=>'空奖','v'=>5),   
    11         );   
    12 
    13         foreach ($prize_arr as $key => $val) {   
    14           $arr[$val['id']] = $val['v'];//概率数组           }    
    15         $rid = $this->get_rand($arr); //根据概率获取奖项id   
    16         $res['yes'] = $prize_arr[$rid-1]['prize']; //中奖项   
    17         unset($prize_arr[$rid-1]); //将中奖项从数组中剔除,剩下未中奖项   
    18         shuffle($prize_arr); //打乱数组顺序   
    19         for($i=0;$i<count($prize_arr);$i++){   
    20           $pr[] = $prize_arr[$i]['prize'];  //未中奖项数组         }   
    21         $res['no'] = $pr;
    22         // var_dump($res);
    23 
    24         if($res['yes']!='空奖'){  
    25             $result['status']=1;  
    26             $result['name']=$res['yes'];  
    27         }else{  
    28             $result['status']=-1;  
    29             $result['msg']=$res['yes'];  
    30         }   
    31         //return $result;  
    32         var_dump($result);
    33     }  
    34 
    35     //计算中奖概率
    36     function get_rand($proArr) {   
    37       $result = '';   
    38 
    39       //概率数组的总概率精度   
    40       $proSum = array_sum($proArr);   
    41       // var_dump($proSum);
    42 
    43       //概率数组循环   
    44       foreach ($proArr as $key => $proCur) {   
    45         $randNum = mt_rand(1, $proSum);  //返回随机整数
    46          if ($randNum <= $proCur) {   
    47           $result = $key;   
    48           break;   
    49         } else {   
    50           $proSum -= $proCur;   
    51         }   
    52       }   
    53       unset ($proArr);   
    54       return $result;   
    55     }
  • 相关阅读:
    一类涉及矩阵范数的优化问题
    MATLAB小实例:读取Excel表格中多个Sheet的数据
    深度多视图子空间聚类
    具有协同训练的深度嵌入多视图聚类
    结构深层聚类网络
    一种数据选择偏差下的去相关聚类方法
    shell编程基础二
    shell编程基础一
    如何处理Teamcenter流程回退情况
    汽车行业数字化车间解决方案
  • 原文地址:https://www.cnblogs.com/zglevk/p/9903427.html
Copyright © 2011-2022 走看看