<?php 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; } } ?>
相关推荐
这里我们探讨两种PHP实现概率算法的方法,它们适用于处理不同规模的奖项池和用户参与情况。 首先,算法一是基于全概率计算的。这个函数`random($ps)`接收一个概率数组`$ps`,例如`array('a'=>0.5,'b'=>0.2,'c'=>0.4...
根据给定文件信息,本文将详细介绍PHP大转盘中奖概率算法实例的知识点,以及如何在PHP程序中实现这一算法。 ### 知识点 #### PHP大转盘中奖概率算法概述 大转盘中奖概率算法是一种用于随机抽取奖品的算法,在很多...
本实例将展示如何用PHP编程实现计算抽奖概率算法,并提供了完整的代码示例,供读者参考。 首先,我们来看PHP随机数运算的相关操作。PHP提供了多种生成随机数的函数,如rand()和mt_rand()。rand()函数基于伪随机数...
在本文中,我们详细探讨了PHP语言实现的抽奖概率算法,该算法特别适用于构建如刮刮卡和大转盘这类抽奖活动。文章的标题“php抽奖概率算法(刮刮卡,大转盘)”明确地指出了本文的主题内容。描述部分强调了该算法在...
【标题】"PHP实例开发源码——佰通一元夺宝系统源码 php版.zip" 提供的是一个基于PHP编程语言实现的一元夺宝系统的完整源代码。这种类型的系统常见于电商平台,用户支付少量金额就有机会赢得商品,具有较强的吸引力...
本文提到的两个PHP哈希算法实例是Times33和CRC32。Times33是一种简单的哈希函数,它的名字来源于其内部乘以33的操作。下面我们将详细讨论这两个算法以及相关的哈希概念。 **Times33算法**: Times33算法的核心在于...
这可能涉及到概率计算和随机数生成算法。 3. 奖品管理模块:管理员可以添加、编辑或删除奖品,设置中奖概率。 4. 数据统计模块:记录并展示抽奖次数、中奖率等数据,便于分析和优化。 5. 页面渲染模块:利用PHP模板...
【PHP抽奖大转盘 Ajax+MYSQL实例源代码】是一个典型的Web开发项目,它结合了PHP、Ajax和MySQL三种技术,用于实现一个可控制概率的在线抽奖功能。在本项目中,PHP作为服务器端脚本语言处理逻辑,Ajax用于实现页面无...
在本文中,我们将通过实例讲解如何用PHP语言实现一个简单中奖算法。 首先,我们需要理解中奖算法的基础概念。中奖算法的本质是根据概率来决定用户是否中奖以及中奖的奖品。要实现这一点,通常需要创建一个包含奖品...
云购夺宝,也称为众筹购物,是一种在线购物模式,用户购买商品的份数会增加中奖概率,当商品总份数达到预设值时,系统通过算法随机选取一名幸运用户获得商品。 在深入探讨源码之前,我们需要了解PHP的基本概念。PHP...
【PHP实例开发源码-魔众大转盘抽奖系统PHP源码.zip】是一个包含PHP编程语言实现的大转盘抽奖系统的完整源代码包。这个系统通常用于网站或应用程序中,为用户提供一种互动式的抽奖体验,增加了用户参与度和娱乐性。在...
4. **随机算法**:抽奖的核心是确定中奖概率和随机选择中奖者。PHP提供了各种随机数生成函数,如`rand()`、`mt_rand()`,可以用于模拟抽奖过程中的随机性。 5. **安全性**:由于涉及到用户参与和可能的奖品发放,...
这个压缩包“PHP实例开发源码—php下支持1632位MD5加解密API接口.zip”包含了一个PHP实现的MD5加密和解密功能的API接口。MD5虽然在安全性上已经不适宜用于密码存储,但在数据完整性校验等方面仍有应用。 1. MD5基础...
HMM则用于处理未在词典中出现的新词,通过概率模型来推测可能的分词结果。 在PHP5.4.x环境下,PSCWS4可能出现的问题主要包括但不限于: 1. **兼容性问题**:由于PHP版本的更新,可能会导致某些函数或语法结构不...