溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

PHP中怎么實現(xiàn)一個大轉(zhuǎn)盤抽獎算法

發(fā)布時間:2021-06-30 16:53:16 來源:億速云 閱讀:136 作者:Leah 欄目:編程語言

本篇文章為大家展示了PHP中怎么實現(xiàn)一個大轉(zhuǎn)盤抽獎算法,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

流程:

1.拼裝獎項數(shù)組;

2.計算概率;

3.返回中獎情況。

代碼如下:中獎概率 ' v ' 可以在后臺設(shè)置,傳到此方法中,注意傳整數(shù)

function get_gift(){  
        //拼裝獎項數(shù)組
        // 獎項id,獎品,概率
        $prize_arr = array(   
          '0' => array('id'=>1,'prize'=>'平板電腦','v'=>0),   
          '1' => array('id'=>2,'prize'=>'數(shù)碼相機','v'=>0),   
          '2' => array('id'=>3,'prize'=>'音箱設(shè)備','v'=>0),   
          '3' => array('id'=>4,'prize'=>'4G優(yōu)盤','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'];//概率數(shù)組           }    
        $rid = $this->get_rand($arr); //根據(jù)概率獲取獎項id   
        $res['yes'] = $prize_arr[$rid-1]['prize']; //中獎項   
        unset($prize_arr[$rid-1]); //將中獎項從數(shù)組中剔除,剩下未中獎項   
        shuffle($prize_arr); //打亂數(shù)組順序   
        for($i=0;$i<count($prize_arr);$i++){   
          $pr[] = $prize_arr[$i]['prize'];  //未中獎項數(shù)組         }   
        $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 = '';   

      //概率數(shù)組的總概率精度   
      $proSum = array_sum($proArr);   
      // var_dump($proSum);

      //概率數(shù)組循環(huán)   
      foreach ($proArr as $key => $proCur) {   
        $randNum = mt_rand(1, $proSum);  //返回隨機整數(shù)
         if ($randNum <= $proCur) {   
          $result = $key;   
          break;   
        } else {   
          $proSum -= $proCur;   
        }   
      }   
      unset ($proArr);   
      return $result;   
    }

上述內(nèi)容就是PHP中怎么實現(xiàn)一個大轉(zhuǎn)盤抽獎算法,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI