亚洲一级免费看,特黄特色大片免费观看播放器,777毛片,久久久久国产一区二区三区四区,欧美三级一区二区,国产精品一区二区久久久久,人人澡人人草

php語(yǔ)言

PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼實(shí)例

時(shí)間:2025-02-22 03:29:06 php語(yǔ)言 我要投稿
  • 相關(guān)推薦

PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼實(shí)例

  導(dǎo)語(yǔ):相信大家都有抽獎(jiǎng)過(guò),但是抽獎(jiǎng)的原理是什么,抽獎(jiǎng)的代碼怎么寫(xiě)?你都知道哪些呢?下面的是百分網(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框架下完成的,使用了一些框架自帶的類(lèi)庫(kù)和函數(shù),下面我會(huì)逐一進(jìn)行說(shuō)明,控制器部分:

  代碼如下

  <?php

  /**

  *

  *

  * @lanfengye <zibin_5257@163.com>

  */

  class ChoujiangAction extends Action {

  //抽獎(jiǎng)的開(kāi)始時(shí)間

  var $begin_time="2012-12-25 14:00:00"; //開(kāi)始時(shí)間  0-不限制

  //抽獎(jiǎng)的結(jié)束時(shí)間

  var $stop_time="0";  //結(jié)束時(shí)間  0-不限制

  //本次抽獎(jiǎng)的獎(jiǎng)項(xiàng)信息,必須按照從大到小的順序進(jìn)行填寫(xiě),id為獎(jiǎng)次,prize為中獎(jiǎng)信息,v為中獎(jiǎng)概率,num為獎(jiǎng)品數(shù)量

  //需要注意的是,該處也必須包含不中獎(jiǎng)的信息,概率從小到大進(jìn)行排序

  var $prize_arr = array(

  '0' => array('id' => 1, 'prize' => '44元購(gòu)買(mǎi)1G/年空間', 'v' => 1,'num'=>1),

  '1' => array('id' => 2, 'prize' => '55元購(gòu)買(mǎi)1G/年空間', 'v' => 2,'num'=>2),

  '2' => array('id' => 3, 'prize' => '66元購(gòu)買(mǎi)1G/年空間', 'v' => 5,'num'=>2),

  '3' => array('id' => 4, 'prize' => '77元購(gòu)買(mǎi)1G/年空間', 'v' => 10,'num'=>3),

  '4' => array('id' => 5, 'prize' => '88元購(gòu)買(mǎi)1G/年空間', 'v' => 15,'num'=>4),

  '5' => array('id' => 6, 'prize' => '99元購(gòu)買(mǎi)1G/年空間', 'v' => 67,'num'=>10),

  );

  //首頁(yè)顯示方法

  public function index(){

  //連接數(shù)據(jù)庫(kù),去獲取本次中獎(jiǎng)的人員名單

  $Choujiang=M('Choujiang');

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

  unset($Choujiang);

  //在首頁(yè)中顯示抽獎(jiǎng)的開(kāi)始時(shí)間

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

  $this->display();

  }

  /**

  * 生成中獎(jiǎng)信息,ajax進(jìn)行請(qǐng)求該方法,需要客戶填寫(xiě)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)正確填寫(xiě)QQ號(hào)碼!');

  exit;

  }

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

  $this->ajaxReturn(1, '抽獎(jiǎng)還沒(méi)有開(kāi)始,開(kāi)始時(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;

  }

  //獲取獎(jiǎng)項(xiàng)信息數(shù)組,來(lái)源于私有成員

  $prize_arr=  $this->prize_arr;

  foreach ($prize_arr as $key => $val) {

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

  }

  //$rid中獎(jiǎng)的序列號(hào)碼

  $rid = $this->get_rand($arr); //根據(jù)概率獲取獎(jiǎng)項(xiàng)id

  $str = $prize_arr[$rid - 1]['prize']; //中獎(jiǎng)項(xiàng)

  $Choujiang=M('Choujiang');

  //從數(shù)據(jù)庫(kù)中獲取特定QQ號(hào)已經(jīng)參加抽獎(jiǎng)的次數(shù),如果大于等于3則提示次數(shù)用完

  if($Choujiang->where("qq_no='{$qq_no}'")->count()>=3){

  $str='您3次抽獎(jiǎng)機(jī)會(huì)已經(jīng)用完!';

  $rid=0;

  //從數(shù)據(jù)庫(kù)中獲取特定獎(jiǎng)項(xiàng)序號(hào)的次數(shù),大于等于設(shè)置的最大次數(shù)則提示獎(jiǎng)品被抽完,如果需要一直中最后一個(gè)紀(jì)念獎(jiǎng),則修改該處即可

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

  $str='很抱歉,您所抽中的獎(jiǎng)項(xiàng)已經(jīng)中完!';

  $rid=0;

  }

  //生成一個(gè)用戶抽獎(jiǎng)的數(shù)據(jù),用來(lái)記錄到數(shù)據(jù)庫(kù)

  $data=array(

  'rid'=>$rid,

  'pop'=>$str,

  'qq_no'=>$qq_no,

  'input_time'=>time()

  );

  //將用戶抽獎(jiǎng)信息數(shù)組寫(xiě)入數(shù)據(jù)庫(kù)

  $Choujiang->add($data);

  unset($Choujiang);

  //ajax返回信息

  $this->ajaxReturn(1, $str);

  }

  /**

  * 根據(jù)概率獲取中獎(jiǎng)號(hào)碼

  */

  private function get_rand($proArr) {

  $result = '';

  //概率數(shù)組的總概率精度

  $proSum = array_sum($proArr);

  //概率數(shù)組循環(huán)

  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)概率算法03-21

php:樹(shù)形結(jié)構(gòu)的算法實(shí)例04-01

php經(jīng)典算法介紹02-26

PHP經(jīng)典算法題03-19

PHP紅包算法04-06

php畫(huà)圖實(shí)例07-16

PHP的樹(shù)形結(jié)構(gòu)算法07-06

PHP幾個(gè)經(jīng)典算法題02-12

php查詢mysql的實(shí)例04-03