Programmation d'algorithmes de loterie PHP

墨辰丷
Libérer: 2023-03-30 10:48:01
original
3813 Les gens l'ont consulté

Cet article présente principalement la programmation de l'algorithme de loterie PHP. Les amis intéressés peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

Les exigences auxquelles l'algorithme de loterie doit répondre sont les suivantes :
1. La probabilité de gagner peut être contrôlée
2. Elle est aléatoire
3. Il est préférable de contrôler le nombre de prix
4. Limiter le nombre de tirages en fonction de l'identifiant ou de l'adresse IP de l'utilisateur, du numéro de téléphone portable, du numéro QQ et d'autres conditions
Dans la phase initiale, ces exigences ont été remplies, puis sur la base des informations sur Internet, une méthode d'extraction par étapes a été adoptée. Jetons un coup d'œil à la situation globale :
Ce programme est réalisé sous le framework ThinkPHP, en utilisant certaines bibliothèques de classes et fonctions fournies avec le framework. Je vais les expliquer un par un ci-dessous. La partie contrôleur :
Le code est le suivant

<?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;
  }
   
}   
?>
Copier après la connexion

L'algorithme est simple à utiliser et a de très bonnes performances d'accès simultané. Il peut être utilisé dans diverses situations avec de légères modifications. Combiné avec la connexion de l'utilisateur et d'autres informations, il peut contrôler efficacement le nombre de tirages pour chaque personne. En changeant le début et la fin en un tableau, vous pouvez compléter le programme pour tirer une loterie à une heure précise chaque jour.

Résumé : Ce qui précède est l'intégralité du contenu de cet article, j'espère qu'il sera utile à l'étude de chacun.

Recommandations associées :

php implémente la fonction d'importation et d'exportation des données au format CSV

paramètres php et Explication détaillée du filtrage des données avec images et textes

Cache de base de données de classification du cache en php

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal