PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼實(shí)例
導(dǎo)語:相信大家都有抽獎(jiǎng)過,但是抽獎(jiǎng)的原理是什么,抽獎(jiǎng)的代碼怎么寫?你都知道哪些呢?下面的是百分網(wǎng)小編為大家搜集的PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼實(shí)例,希望對(duì)你能有所幫助。
1.可以控制中獎(jiǎng)的概率
2.具有隨機(jī)性
3.最好可以控制獎(jiǎng)品的數(shù)量
4.根據(jù)用戶ID或者ip、手機(jī)號(hào)、QQ號(hào)等條件限制抽獎(jiǎng)次數(shù)
初期就這些需求,然后根據(jù)網(wǎng)上的資料,采用了一種階段式抽取的方法,大家下面看一下整體的程序:
該程序是在ThinkPHP框架下完成的,使用了一些框架自帶的類庫和函數(shù),下面我會(huì)逐一進(jìn)行說明,控制器部分:
代碼如下
<?php
/**
*
*
* @lanfengye <zibin_5257@163.com>
*/
class ChoujiangAction extends Action {
/pic/p>
var $begin_time="2012-12-25 14:00:00"; /pic/p>
/pic/p>
var $stop_time="0"; /pic/p>
/pic/p>
/pic/p>
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),
);
/pic/p>
public function index(){
/pic/p>
$Choujiang=M('Choujiang');
$this->assign('list', $Choujiang->where("rid>0")->order('id desc')->select());
unset($Choujiang);
/pic/p>
$this->assign('begin_time',$this->begin_time);
$this->display();
}
/**
* 生成中獎(jiǎng)信息,ajax進(jìn)行請(qǐng)求該方法,需要客戶填寫QQ號(hào)碼
*/
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, '請(qǐng)正確填寫QQ號(hào)碼!');
exit;
}
if(!empty($this->begin_time) && time()<strtotime($this->begin_time)){
$this->ajaxReturn(1, '抽獎(jiǎng)還沒有開始,開始時(shí)間為:'.$this->begin_time);
exit;
}
if(!empty($this->stop_time) && time()>strtotime($this->stop_time)){
$this->ajaxReturn(1, '本次抽獎(jiǎng)已經(jīng)結(jié)束,結(jié)束時(shí)間為:'.$this->stop_time);
exit;
}
/pic/p>
$prize_arr= $this->prize_arr;
foreach ($prize_arr as $key => $val) {
$arr[$val['id']] = $val['v'];
}
/pic/p>
$rid = $this->get_rand($arr); /pic/p>
$str = $prize_arr[$rid - 1]['prize']; /pic/p>
$Choujiang=M('Choujiang');
/pic/p>
if($Choujiang->where("qq_no='{$qq_no}'")->count()>=3){
$str='您3次抽獎(jiǎng)機(jī)會(huì)已經(jīng)用完!';
$rid=0;
/pic/p>
}elseif ($Choujiang->where("rid={$rid}")->count()>=$prize_arr[$rid-1]['num']) {
$str='很抱歉,您所抽中的獎(jiǎng)項(xiàng)已經(jīng)中完!';
$rid=0;
}
/pic/p>
$data=array(
'rid'=>$rid,
'pop'=>$str,
'qq_no'=>$qq_no,
'input_time'=>time()
);
/pic/p>
$Choujiang->add($data);
unset($Choujiang);
/pic/p>
$this->ajaxReturn(1, $str);
}
/**
* 根據(jù)概率獲取中獎(jiǎng)號(hào)碼
*/
private function get_rand($proArr) {
$result = '';
/pic/p>
$proSum = array_sum($proArr);
/pic/p>
foreach ($proArr as $key => $proCur) {
$randNum = mt_rand(1, $proSum);
if ($randNum <= $proCur) {
$result = $key;
break;
} else {
$proSum -= $proCur;
}
}
unset($proArr);
return $result;
}
}
?>
【PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼實(shí)例】相關(guān)文章:
PHP實(shí)現(xiàn)抽獎(jiǎng)概率算法09-07
php:樹形結(jié)構(gòu)的算法實(shí)例12-13
php經(jīng)典算法介紹02-26
PHP經(jīng)典算法題10-22
PHP紅包算法12-17
php畫圖實(shí)例09-15
PHP的樹形結(jié)構(gòu)算法09-19
PHP幾個(gè)經(jīng)典算法題02-12