分享一个PHP抽奖算法程序代码

抽奖算法需要满足的需求如下:

1.可以控制中奖的概率

2.具有随机性

3.最好可以控制奖品的数量

4.根据用户ID或者ip、手机号、QQ号等条件限制抽奖次数

初期就这些需求,然后根据网上的资料,采用了一种阶段式抽取的方法,大家下面看一下整体的程序:

该程序是在ThinkPHP框架下完成的,使用了一些框架自带的类库和函数,下面我会逐一进行说明,控制器部分:

代码如下

<?php

/**
 *
 *
 * @lanfengye <[email protected]>
 */
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);

    if(empty($qq_no)){
      $this->ajaxReturn(1, ‘请正确填写QQ号码!‘);
      exit;
    }

    if(!empty($this->begin_time) && time()<strtotime($this->begin_time)){
      $this->ajaxReturn(1, ‘抽奖还没有开始,开始时间为:‘.$this->begin_time);
      exit;
    }

    if(!empty($this->stop_time) && time()>strtotime($this->stop_time)){
      $this->ajaxReturn(1, ‘本次抽奖已经结束,结束时间为:‘.$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->ajaxReturn(1, $str);
  }

  /**
   * 根据概率获取中奖号码
   */
  private function get_rand($proArr) {
    $result = ‘‘;
    //概率数组的总概率精度
    $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;
  }

}
?>
时间: 2024-08-04 19:19:01

分享一个PHP抽奖算法程序代码的相关文章

分享一个转盘抽奖组件

转盘抽奖组件 1.支持分享到微信支持分享应用拿积分,积分抽奖,积分兑换奖品 其他功能: 1.按照自己的需求支持分享到多个平台:                2.支持截屏涂鸦功能:         3.积分功能: (1)用户分享获得积分: (2)邀请好友获得积分: 积分兑换活动,抽奖功能: (1)活动介绍: (2)用户可以分享应用拿积分: (3)拿到积分可以参与抽奖或者直接领取奖品,抽奖大转盘: <ignore_js_op> (4)领取奖品:   下载地址:http://youtui.oss-

分享一个PHP抽奖算法

设置中奖的列表 字段说明 id 奖品编号 prize 奖品名称 v 中奖概率 $prize_arr = array( array('id' => 1, 'prize' => '笔记本电脑', 'v' => 1), array('id' => 2, 'prize' => '华为手机', 'v' => 5), array('id' => 3, 'prize' => '蓝牙音箱', 'v' => 10), array('id' => 4, 'prize

分享一个jquery功能强大的提示信息插件代码

代码属于提示文字特效,很好,使用有些复杂,请参demo使用 下载地址:jquery功能强大的提示信息插件代码 预览DEMO:DEMO 分享一个jquery功能强大的提示信息插件代码,布布扣,bubuko.com

分享一个分布式消息总线,基于.NET Socket Tcp的发布-订阅框架,附代码下载

一.分布式消息总线 在很多MIS项目之中都有这样的需求,需要一个及时.高效的的通知机制,即比如当使用者A完成了任务X,就需要立即告知使用者B任务X已经完成,在通常的情况下,开发人中都是在使用者B所使用的程序之中写数据库轮循代码,这样就会产品一个很严重的两个问题,第一个问题是延迟,轮循机制要定时执行,必须会引起延迟,第二个问题是数据库压力过大,当进行高频度的轮循会生产大量的数据库查询,并且如果有大量的使用者进行轮循,那数据库的压力就更大了. 那么在这个时间,就需要一套能支持发布-订阅模式的分布式消

分享一个从网上获取天气的代码

项目中需要查询天气,自己写了一段代码从中国天气网和MSN上查天气,中国天气网查中国天气,MSN查世界天气. MSN用到的数据结构 1 /// <summary> 2 /// 根据城市名查询MSN天返回的城市编码信息类 3 /// </summary> 4 public class Location 5 { 6 //全名 例如 杭州,浙江,中国 7 public string FullName { get; set; } 8 9 //国家 10 public string Count

分享一个从国外网站看到的socket程序,程序并不强悍,但能从代码中看到老外是怎么写代码的,咱可以取长补短

原文:分享一个从国外网站看到的socket程序,程序并不强悍,但能从代码中看到老外是怎么写代码的,咱可以取长补短 源代码下载地址:http://www.zuidaima.com/share/1550463702764544.htm package com.zuidaima.xs; /**************************************************************** * Version : 1.0 * Date : 02/03/2007 * Autho

分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容

分享一个自定义的console类 让你不再纠结JS中的调试代码的兼容 在写JS的过程中,为了调试我们常常会 写很多 console.log.console.info.console.group.console.warn.console.error代码来查看JS 的运行情况,但发布时又因为IE不支持console,又要去掉这些代码,一不小心就会出错 问题的产生 在写JS的过程中,为了调试我们常常会写很多 console.log.console.info.console.group.console.

分享一个很实用的java代码,可以将以逗号分隔的数字以从大到小的方式排序后返回

原文:分享一个很实用的java代码,可以将以逗号分隔的数字以从大到小的方式排序后返回 源代码下载地址:http://www.zuidaima.com/share/1550463693032448.htm 对于web开发中,多个id的排序很实用,有需要的牛人可以下载. package com.zuidaima.math; import java.util.Arrays; /** *@author www.zuidaima.com **/ public class SortIDString { pu

分享一个简单的简单的SQLHelper类

分享一个简单的简单的SQLHelper类,代码如下: 1 class SqlHelper 2 { 3 public static readonly string connstr = 4 ConfigurationManager.ConnectionStrings["dbConnStr"].ConnectionString; 5 6 public static int ExecuteNonQuery(string cmdText, 7 params SqlParameter[] para