>백엔드 개발 >PHP 튜토리얼 >PHP 복권 기능 예

PHP 복권 기능 예

*文
*文원래의
2017-12-27 15:24:306366검색

이 글에서는 주로 PHP 복권 알고리즘 프로그래밍을 공유합니다. 누구나 일상 생활에서 복권을 접하게 될 것입니다. PHP를 사용하여 복권 알고리즘을 구현하는 방법을 설명합니다. 그것이 모두에게 도움이 되기를 바랍니다.

복권 알고리즘이 충족해야 하는 요구 사항은 다음과 같습니다.
1. 당첨 확률은 제어할 수 있습니다.
2. 당첨 수는 제어하는 ​​것이 가장 좋습니다.
4. 사용자 ID 또는 IP, 휴대폰 번호, QQ 번호 특정 조건에 따라 추첨 횟수 제한
초기에는 이러한 요구 사항을 충족한 후 인터넷 정보를 기반으로 단계적 추출 방법을 채택합시다. 전체 프로그램을 살펴보세요.
이 프로그램은 내장된 클래스 라이브러리와 함수를 사용하여 ThinkPHP 프레임워크에서 완성되었습니다. 컨트롤러 부분은 아래에서 하나씩 설명하겠습니다.

코드는 다음과 같습니다.


<?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;
  }
   
}   
?>


알고리즘은 사용이 간단하고 몇 가지 변경만으로 동시 액세스 성능이 매우 좋습니다. 다양한 경우에 사용되며 사용자 로그인 및 기타 정보와 결합되어 효과적으로 제어할 수 있습니다. 각 사람의 추첨 수. 시작과 끝을 배열로 변경하면 매일 특정 시간에 로또를 추첨하는 프로그램을 완성할 수 있습니다.

관련 권장사항:

php는 심판 채점기를 구현합니다.

PHP에서 생성된 바코드 예제

php는 무작위 빨간 봉투 알고리즘을 구현합니다

위 내용은 PHP 복권 기능 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.