Heim  >  Artikel  >  Backend-Entwicklung  >  Programmierung von PHP-Lotteriealgorithmen

Programmierung von PHP-Lotteriealgorithmen

墨辰丷
墨辰丷Original
2018-06-07 09:50:513751Durchsuche

In diesem Artikel wird hauptsächlich die Programmierung des PHP-Lotteriealgorithmus vorgestellt. Ich hoffe, dass er für alle hilfreich ist.

Die Anforderungen, die der Lotteriealgorithmus erfüllen muss, sind wie folgt:
1. Die Gewinnwahrscheinlichkeit kann kontrolliert werden
2. Sie ist zufällig
3. Es ist am besten, die Anzahl der Preise zu kontrollieren
4. Begrenzen Sie die Anzahl der Ziehungen basierend auf Benutzer-ID oder IP, Mobiltelefonnummer, QQ-Nummer und anderen Bedingungen
In der Anfangsphase wurden diese Anforderungen erfüllt und dann Basierend auf den Informationen im Internet wurde eine abgestufte Extraktionsmethode übernommen. Schauen wir uns die Gesamtsituation an:
Dieses Programm wird unter dem ThinkPHP-Framework erstellt und verwendet einige Klassenbibliotheken und Funktionen, die mit dem Framework geliefert werden. Ich werde sie unten einzeln erklären:
Der Code lautet wie folgt

<?php
 
/**
 * 
 *
 * @lanfengye <zibin_5257@163.com>
 */
class ChoujiangAction extends Action {
   //抽奖的开始时间
  var $begin_time="2012-12-25 14:00:00"; //开始时间 0-不限制
  //抽奖的结束时间
  var $stop_time="0"; //结束时间 0-不限制
   
  //本次抽奖的奖项信息,必须按照从大到小的顺序进行填写,id为奖次,prize为中奖信息,v为中奖概率,num为奖品数量
  //需要注意的是,该处也必须包含不中奖的信息,概率从小到大进行排序
  var $prize_arr = array(
    &#39;0&#39; => array(&#39;id&#39; => 1, &#39;prize&#39; => &#39;44元购买1G/年空间&#39;, &#39;v&#39; => 1,&#39;num&#39;=>1),
    &#39;1&#39; => array(&#39;id&#39; => 2, &#39;prize&#39; => &#39;55元购买1G/年空间&#39;, &#39;v&#39; => 2,&#39;num&#39;=>2),
    &#39;2&#39; => array(&#39;id&#39; => 3, &#39;prize&#39; => &#39;66元购买1G/年空间&#39;, &#39;v&#39; => 5,&#39;num&#39;=>2),
    &#39;3&#39; => array(&#39;id&#39; => 4, &#39;prize&#39; => &#39;77元购买1G/年空间&#39;, &#39;v&#39; => 10,&#39;num&#39;=>3),
    &#39;4&#39; => array(&#39;id&#39; => 5, &#39;prize&#39; => &#39;88元购买1G/年空间&#39;, &#39;v&#39; => 15,&#39;num&#39;=>4),
    &#39;5&#39; => array(&#39;id&#39; => 6, &#39;prize&#39; => &#39;99元购买1G/年空间&#39;, &#39;v&#39; => 67,&#39;num&#39;=>10),
  );
   
 
  //首页显示方法   
  public function index(){
    //连接数据库,去获取本次中奖的人员名单
    $Choujiang=M(&#39;Choujiang&#39;);
    $this->assign(&#39;list&#39;, $Choujiang->where("rid>0")->order(&#39;id desc&#39;)->select());
    unset($Choujiang);
     
    //在首页中显示抽奖的开始时间
    $this->assign(&#39;begin_time&#39;,$this->begin_time);
     
    $this->display();
  }
   
 
   
  /**
   * 生成中奖信息,ajax进行请求该方法,需要客户填写QQ号码
   */
  public function make() {
    $qq_no= trim($_POST[&#39;qq_no&#39;]);
    import(&#39;ORG.Util.Input&#39;);
    $qq_no=Input::getVar($qq_no);
     
    if(empty($qq_no)){
      $this->ajaxReturn(1, &#39;请正确填写QQ号码!&#39;);
      exit;
    }
     
    if(!empty($this->begin_time) && time()<strtotime($this->begin_time)){
      $this->ajaxReturn(1, &#39;抽奖还没有开始,开始时间为:&#39;.$this->begin_time);
      exit;
    }
     
    if(!empty($this->stop_time) && time()>strtotime($this->stop_time)){
      $this->ajaxReturn(1, &#39;本次抽奖已经结束,结束时间为:&#39;.$this->stop_time);
      exit;
    }
     
     //获取奖项信息数组,来源于私有成员
    $prize_arr= $this->prize_arr;
     
    foreach ($prize_arr as $key => $val) {
      $arr[$val[&#39;id&#39;]] = $val[&#39;v&#39;];
    }
    //$rid中奖的序列号码
    $rid = $this->get_rand($arr); //根据概率获取奖项id
     
    $str = $prize_arr[$rid - 1][&#39;prize&#39;]; //中奖项 
     
    $Choujiang=M(&#39;Choujiang&#39;);
     
      //从数据库中获取特定QQ号已经参加抽奖的次数,如果大于等于3则提示次数用完
    if($Choujiang->where("qq_no=&#39;{$qq_no}&#39;")->count()>=3){
      $str=&#39;您3次抽奖机会已经用完!&#39;;
      $rid=0;
      //从数据库中获取特定奖项序号的次数,大于等于设置的最大次数则提示奖品被抽完,如果需要一直中最后一个纪念奖,则修改该处即可
    }elseif ($Choujiang->where("rid={$rid}")->count()>=$prize_arr[$rid-1][&#39;num&#39;]) {
      $str=&#39;很抱歉,您所抽中的奖项已经中完!&#39;;
      $rid=0;
    }
    //生成一个用户抽奖的数据,用来记录到数据库
    $data=array(
      &#39;rid&#39;=>$rid,
      &#39;pop&#39;=>$str,
      &#39;qq_no&#39;=>$qq_no,
      &#39;input_time&#39;=>time()
    );
    //将用户抽奖信息数组写入数据库
     
    $Choujiang->add($data);
    unset($Choujiang);
     
     //ajax返回信息
    $this->ajaxReturn(1, $str);
  }
   
  /**
   * 根据概率获取中奖号码
   */
  private function get_rand($proArr) {
    $result = &#39;&#39;;
    //概率数组的总概率精度 
    $proSum = array_sum($proArr);
    //概率数组循环 
    foreach ($proArr as $key => $proCur) {
      $randNum = mt_rand(1, $proSum);
      if ($randNum <= $proCur) {
        $result = $key;
        break;
      } else {
        $proSum -= $proCur;
      }
    }
    unset($proArr);
    return $result;
  }
   
}   
?>

Der Algorithmus ist einfach zu verwenden und bietet eine sehr gute Leistung beim gleichzeitigen Zugriff kann in verschiedenen Situationen mit geringfügigen Änderungen verwendet werden. In Kombination mit der Benutzeranmeldung und anderen Informationen kann die Anzahl der Ziehungen für jede Person effektiv gesteuert werden. Durch Ändern von Anfang und Ende in ein Array können Sie das Programm so vervollständigen, dass jeden Tag zu einer bestimmten Zeit eine Lotterie gezogen wird.

Zusammenfassung: Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe, dass er für das Studium aller hilfreich sein wird.

Verwandte Empfehlungen:

PHP implementiert die Import- und Exportfunktion von CSV-Formatdaten.

PHP-Parameter und Ausführliche Erklärung der Datenfilterung mit Bildern und Texten

Cache-Klassifizierungsdatenbank-Cache in PHP

Das obige ist der detaillierte Inhalt vonProgrammierung von PHP-Lotteriealgorithmen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn