好好学习,天天向上,自学网欢迎您!
当前位置:首页 >  考试 >  计算机类 > 内容页

PHP中奖几率的抽奖算法顺序代码实例

2021-09-12 20:26:57计算机类访问手机版199

  PHP中奖几率的抽奖算法顺序代码实例

  导语:相信大师都有抽奖过,但是抽奖的道理是什么,抽奖的代码怎么写?你都知道哪些呢?下面的是小编为大师汇集的PHP中奖几率的抽奖算法顺序代码实例,但愿对你能有所帮忙。

  1.可以把持中奖的几率

  2.具有随机性

  3.最好可以把持奖品的数量

  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

  '0' => array'id' => 1, 'prize' => '44元采办1G/年空间', 'v' => 1,'num'=>1,

  '1' => array'id' => 2, 'prize' => '55元采办1G/年空间', 'v' => 2,'num'=>2,

  '2' => array'id' => 3, 'prize' => '66元采办1G/年空间', 'v' => 5,'num'=>2,

  '3' => array'id' => 4, 'prize' => '77元采办1G/年空间', 'v' => 10,'num'=>3,

  '4' => array'id' => 5, 'prize' => '88元采办1G/年空间', 'v' => 15,'num'=>4,

  '5' => array'id' => 6, 'prize' => '99元采办1G/年空间', 'v' => 67,'num'=>10,

  ;

  //首页表现办法

  public function index

  //连接数据库,去获得本次中奖的'人员名单

  $Choujiang=M'Choujiang';

  $this->assign'list', $Choujiang->where"rid>0"->order'id desc'->select;

  unset$Choujiang;

  //在首页中表现抽奖的入手下手时间

  $this->assign'begin_time',$this->begin_time;

  $this->display;

  /**

  * 生成中奖信息,ajax进行哀求该办法,必要客户填写QQ号码

  */

  public function make

  $qq_no= trim$_POST['qq_no'];

  import'ORG.Util.Input';

  $qq_no=Input::getVar$qq_no;

  ifempty$qq_no

  $this->ajaxReturn1, '请正确填写QQ号码!';

  exit;

  if!empty$this->begin_time && time<strtotime$this->begin_time

  $this->ajaxReturn1, '抽奖尚未入手下手,入手下手时间为:'.$this->begin_time;

  exit;

  if!empty$this->stop_time && time>strtotime$this->stop_time

  $this->ajaxReturn1, '本次抽奖曾经结束,结束时间为:'.$this->stop_time;

  exit;

  //获得奖项信息数组,根源于公有成员

  $prize_arr= $this->prize_arr;

  foreach $prize_arr as $key => $val

  $arr[$val['id']] = $val['v'];

  //$rid中奖的序列号码

  $rid = $this->get_rand$arr; //按照几率获得奖项id

  $str = $prize_arr[$rid - 1]['prize']; //中奖项

  $Choujiang=M'Choujiang';

  //从数据库中获得特定QQ号曾经参与抽奖的次数,假如大于即是3则提示次数用完

  if$Choujiang->where"qq_no='$qq_no'"->count>=3

  $str='您3次抽奖机遇曾经用完!';

  $rid=0;

  //从数据库中获得特定奖项序号的次数,大于即是设置的最大次数则提示奖品被抽完,假如必要不断中最后一个怀念奖,则点窜该处便可

  elseif $Choujiang->where"rid=$rid"->count>=$prize_arr[$rid-1]['num']

  $str='很抱愧,您所抽中的奖项曾经中完!';

  $rid=0;

  //生成一个用户抽奖的数据,用来记实到数据库

  $data=array

  'rid'=>$rid,

  'pop'=>$str,

  'qq_no'=>$qq_no,

  'input_time'=>time

  ;

  //将用户抽奖信息数组写入数据库

  $Choujiang->add$data;

  unset$Choujiang;

  //ajax返复书息

  $this->ajaxReturn1, $str;

  /**

  * 按照几率获得中奖号码

  */

  private function get_rand$proArr

  $result = '';

  //几率数组的总几率精度

  $proSum = array_sum$proArr;

  //几率数组循环

  foreach $proArr as $key => $proCur

  $randNum = mt_rand1, $proSum;

  if $randNum <= $proCur

  $result = $key;

  break;

  else

  $proSum -= $proCur;

  unset$proArr;

  return $result;

  ?>

TAG标签: 抽奖 中奖 概率 算法 程序代码