• 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     }
  • 相关阅读:
    sql中where和having的区别
    mysql中locate和substring函数使用
    使用jdk进行数据迁移(sqlite迁移mysql)
    mysql数值函数
    mysql字符串函数
    zabbix-2.2.2(Ubuntu 14.04 LTS/OpenLogic 7.2)
    Piwik-2.16.1 (OpenLogic CentOS7.2)
    Nagios-4.1.1 (OpenLogic CentOS 7.2)
    Bugzilla-5.0.3 (OpenLogic CentOS 7.2)
    GitLab-CE-8.9.4 (OpenLogic CentOS 7.2)
  • 原文地址:https://www.cnblogs.com/zglevk/p/9903427.html
Copyright © 2020-2023  润新知