摘要:注意其中的必須為整數,你可以將對應的獎項的設置成,即意味著該獎項抽中的幾率是,數組中的總和基數,基數越大越能體現概率的準確性。每次前端頁面的請求,循環獎項設置數組,通過概率計算函數獲取抽中的獎項。
基本算法
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; }
這是一段經典的概率算法,$proArr是一個預先設置的數組,假設數組為:array(100,200,300,400),開始是從1,1000這個概率范圍內篩選第一個數是否在他的出現概率范圍之內, 如果不在,則將概率空減,也就是k的值減去剛剛的那個數字的概率空間,在本例當中就是減去100,也就是說第二個數是在1,900這個范圍內篩選的。這樣篩選到最終,總會有一個數滿足要求。就相當于去一個箱子里摸東西,第一個不是,第二個不是,第三個還不是,那最后一個一定是。這個算法簡單,而且效率非常高,關鍵是這個算法已在我們以前的項目中有應用,尤其是大數據量的項目中效率非常棒。
接下來我們通過PHP配置獎項。
$prize_arr = array( "0" => array("id"=>1,"prize"=>"平板電腦","v"=>1), "1" => array("id"=>2,"prize"=>"數碼相機","v"=>5), "2" => array("id"=>3,"prize"=>"音箱設備","v"=>10), "3" => array("id"=>4,"prize"=>"4G優盤","v"=>12), "4" => array("id"=>5,"prize"=>"10Q幣","v"=>22), "5" => array("id"=>6,"prize"=>"下次沒準就能中哦","v"=>50), );
$prize_arr是一個二維數組,記錄了所有本次抽獎的獎項信息,其中id表示中獎等級,prize表示獎品,v表示中獎概率。注意其中的v必須為整數,你可以將對應的獎項的v設置成0,即意味著該獎項抽中的幾率是0,數組中v的總和(基數),基數越大越能體現概率的準確性。本例中v的總和為100,那么平板電腦對應的中獎概率就是1%,如果v的總和是10000,那中獎概率就是萬分之一了。
每次前端頁面的請求,PHP循環獎項設置數組,通過概率計算函數get_rand獲取抽中的獎項id。將中獎獎品保存在數組$res[‘yes’]中,而剩下的未中獎的信息保存在$res[‘no’]中,最后輸出json個數數據給前端頁面。
//如果中獎數據是放在數據庫里,這里就需要進行判斷中獎數量 //在中1、2、3等獎的,如果達到最大數量的則unset相應的獎項,避免重復中大獎 //code here eg:unset($prize_arr["0"]) foreach ($prize_arr as $key => $val) { $arr[$val["id"]] = $val["v"]; } $rid = get_rand($arr); //根據概率獲取獎項id $res["yes"] = $prize_arr[$rid-1]["prize"]; //中獎項 //將中獎項從數組中剔除,剩下未中獎項,如果是數據庫驗證,這里可以省掉 unset($prize_arr[$rid-1]); shuffle($prize_arr); //打亂數組順序 for($i=0;$i貼上我一個簡單案例
class Award extends CI_Controller { public function __construct() { parent::__construct(); $this->load->library("Cookie"); } //抽獎 public function awardStart(){ $code = Cookie::get("awardCode"); $validate_code = $this->input->post("validateCode"); if(!empty($code) && $code == $validate_code){ //iPhone7 32G Ipad 2 50元話費 交易秘笈 高級課件 黃金馬甲 再來一次 $prize_arr = array( "0" => array("id"=>1,"prize"=>"iPhone7 32G","v"=>0), "1" => array("id"=>2,"prize"=>"Ipad 2","v"=>1), "2" => array("id"=>3,"prize"=>"50元話費","v"=>2), "3" => array("id"=>4,"prize"=>"交易秘笈","v"=>100), "4" => array("id"=>5,"prize"=>"高級課件","v"=>100), "5" => array("id"=>6,"prize"=>"黃金馬甲","v"=>100), "6" => array("id"=>7,"prize"=>"再來一次","v"=>100), ); foreach ($prize_arr as $key => $val) { $arr[$val["id"]] = $val["v"]; } $rid = $this->get_rand($arr); //根據概率獲取獎項id $award = $prize_arr[$rid-1]["prize"]; //中獎項 //($rid==7 再來一次) if($rid != 7){ Cookie::set("awardCode", "",-1); Cookie::set("awardMobile", "",-1); //記錄用戶所獲獎項 $mobile = Cookie::get("awardMobile"); //$sql = "INSERT INTO live_mobile_award_record(mobile,award,ctime) VALUES("{$mobile}","{$award}","{$time}") "; $sql = "UPDATE live_mobile_award SET award ="{$award}" WHERE mobile = "{$mobile}""; $result = $this->db->query($sql); } $data = array( "code"=>"1", "msg"=>$rid-1, ); exit(json_encode($data)); }else{ $data = array( "code"=>"0", "msg"=>"", ); exit(json_encode($data)); } } /* * 經典的概率算法, * $proArr是一個預先設置的數組, * 假設數組為:array(100,200,300,400), * 開始是從1,1000 這個概率范圍內篩選第一個數是否在他的出現概率范圍之內, * 如果不在,則將概率空間,也就是k的值減去剛剛的那個數字的概率空間, * 在本例當中就是減去100,也就是說第二個數是在1,900這個范圍內篩選的。 * 這樣 篩選到最終,總會有一個數滿足要求。 * 就相當于去一個箱子里摸東西, * 第一個不是,第二個不是,第三個還不是,那最后一個一定是。 * 這個算法簡單,而且效率非常 高, * 關鍵是這個算法已在我們以前的項目中有應用,尤其是大數據量的項目中效率非常棒。 */ 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; } //提交表單,手機號入庫 public function awardResult(){ if(isset($_POST["mobileCode"])&&!empty($_POST["mobileCode"])){ if($this->isMobile($_POST["mobilePhone"])){ $code = Cookie::get("awardCode"); $input_mobile = $_POST["mobilePhone"]; $input_code = $_POST["mobileCode"]; $ipaddress = ip2long($this->input->ip_address()); if($code == md5($input_mobile.$input_code)){ $time = time(); $ssql = "SELECT count(*) num FROM live_mobile_award WHERE mobile="{$input_mobile}""; $rs = $this->db->query($ssql)->result_array();; if(!$rs[0]["num"]){ $sql = "INSERT INTO live_mobile_award(mobile,ipaddress,ctime) VALUES("{$input_mobile}","{$ipaddress}","{$time}") "; $result = $this->db->query($sql); if($result){ Cookie::set("awardMobile", $input_mobile,600); $data = array( "code"=>"1", "msg"=>$code, ); exit(json_encode($data)); } }else{ $data = array( "code"=>"2", "msg"=>"sorry,你已經參加過此活動了!", ); exit(json_encode($data)); } }else{ $data = array( "code"=>"0", "msg"=>"手機號碼有誤,或驗證碼已經過時,請核實!", ); exit(json_encode($data)); } } } } //獲取抽獎驗證碼 public function getAwardCode(){ $tel = $_POST["inputTel"]; if($this->isMobile($tel)){ $sql = "select count(*) num from live_mobile_award where mobile = "{$tel}""; $result = $this->db->query($sql)->result_array(); if($result[0]["num"]){ $data = array( "code"=>"0", "msg"=>"對不起,該用戶已經參加活動!", ); exit(json_encode($data)); }else{ $code = rand(1000,9999); $msg = "您好!你的驗證碼是:".$code.",請于10分鐘內輸入驗證。"; $url = "http://222.73.117.156/msg/HttpBatchSendSM?account=****&pswd=****&mobile=".$tel."&msg=".$msg."&needstatus=true"; $re = file_get_contents($url); $rest = explode(",",$re); if(strlen($rest[1])>3) { Cookie::set("awardCode", md5($tel.$code),600); $data = array( "code"=>"1", "msg"=>"發送成功!", "rest"=>$rest ); exit(json_encode($data)); } else { $data = array( "code"=>"0", "msg"=>"發送失敗!", "rest"=>$rest ); exit(json_encode($data)); } } } } //驗證手機號碼 public function isMobile($tel) { if(preg_match("/^1[34578]{1}d{9}$/",$tel)){ return true; }else{ return false; } } }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/22416.html
摘要:目錄如何用提高效率后端掘金經常有人說我應該學一門語言,比如之類,但是卻不知道如何入門。本文將通過我是如何開發公司年會抽獎系統的后端掘金需求出現年會將近,而年會抽獎環節必不可少,但是抽獎系統卻還沒有。 云盤一個個倒下怎么辦?無需編碼,手把手教你搭建至尊私享云盤 - 工具資源 - 掘金微盤掛了,360倒了,百度云盤也立了Flag。能讓我們在云端儲存分享文件的服務越來越少了。 買一堆移動硬盤...
摘要:演示下載地址效果圖三個金蛋一把錘子及中獎結果代碼如下錘子當鼠標滑向金蛋時,錘子會僅靠金蛋右上方,通過來控制位置。當揮動錘子砸向金蛋前,我們先把金蛋中的數字編號隱藏起來。最后,我們向后臺發送一個請求,后臺程序會處理獎項分配并把中獎結果返回。 演示下載地址:http://www.erdangjiade.com/js...效果圖:showImg(https://segmentfault.co...
摘要:演示下載地址效果圖三個金蛋一把錘子及中獎結果代碼如下錘子當鼠標滑向金蛋時,錘子會僅靠金蛋右上方,通過來控制位置。當揮動錘子砸向金蛋前,我們先把金蛋中的數字編號隱藏起來。最后,我們向后臺發送一個請求,后臺程序會處理獎項分配并把中獎結果返回。 演示下載地址:http://www.erdangjiade.com/js...效果圖:showImg(https://segmentfault.co...
摘要:演示下載地址效果圖三個金蛋一把錘子及中獎結果代碼如下錘子當鼠標滑向金蛋時,錘子會僅靠金蛋右上方,通過來控制位置。當揮動錘子砸向金蛋前,我們先把金蛋中的數字編號隱藏起來。最后,我們向后臺發送一個請求,后臺程序會處理獎項分配并把中獎結果返回。 演示下載地址:http://www.erdangjiade.com/js...效果圖:showImg(https://segmentfault.co...
閱讀 1207·2019-08-30 15:55
閱讀 954·2019-08-30 15:55
閱讀 2150·2019-08-30 15:44
閱讀 2879·2019-08-29 14:17
閱讀 1130·2019-08-29 12:45
閱讀 3301·2019-08-26 10:48
閱讀 3133·2019-08-23 18:18
閱讀 2599·2019-08-23 16:47