- 相干保举
PHP中奖几率的抽奖算法法式代码实例
导语:信任大师都有抽奖过,可是抽奖的道理是甚么,抽奖的代码怎样写?你都晓得哪些呢?上面的是百分网小编为大师汇集的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),
);
//上海龙凤419显现体例
public function index(){
//毗连数据库,去获得本次中奖的职员名单
$Choujiang=M('Choujiang');
$this->assign('list', $Choujiang->where("rid>0")->order('id desc')->select());
unset($Choujiang);
//在上海龙凤419中显现抽奖的起头时候
$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中奖几率的抽奖算法法式代码实例】相干文章:
PHP socket的设置装备摆设及实例10-16
php查问mysql的实例09-09
一段典范php mysql分页法式代码08-11
php中fsockopen用法实例06-20
php简略伪静态实例09-16
PHP疾速排序算法剖析10-09
PHP排序算法类讲授07-18
PHP处置暗码的几种体例实例09-27
PHP天生器简略实例09-07
PHP合适PSR编程标准的实例07-31