首頁  >  文章  >  後端開發  >  PHP實作轉盤抽獎演算法分享php實例

PHP實作轉盤抽獎演算法分享php實例

jacklove
jacklove原創
2018-06-26 16:59:451913瀏覽

這篇文章主要為大家詳細介紹了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<count($prize_arr);$i++){  
     $pr[] = $prize_arr[$i][&#39;prize&#39;]; //未中奖项数组 
    }  
    $res[&#39;no&#39;] = $pr; 
    // var_dump($res);

     
    if($res[&#39;yes&#39;]!=&#39;空奖&#39;){ 
      $result[&#39;status&#39;]=1; 
      $result[&#39;name&#39;]=$res[&#39;yes&#39;]; 
    }else{ 
      $result[&#39;status&#39;]=-1; 
      $result[&#39;msg&#39;]=$res[&#39;yes&#39;]; 
    }  
    //return $result; 
    var_dump($result);
  } 

  //计算中奖概率
  function get_rand($proArr) {  
   $result = &#39;&#39;;  
   //概率数组的总概率精度  
   $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;  
  }

效果圖:

##以上就是本文的全部內容,希望對大家的學習有幫助,也希望大家多多支持php中文網。

您可能感興趣的文章:

PHP使用curl_multi實作並發請求的方法範例php技巧

PHP效能測試工具xhprof安裝與使用方法詳解php技巧

#PHP實作透過strace定位故障原因的方法php技巧

#

以上是PHP實作轉盤抽獎演算法分享php實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn