摘要:注意其中的必須為整數(shù),你可以將對應(yīng)的獎項的設(shè)置成,即意味著該獎項抽中的幾率是,數(shù)組中的總和基數(shù),基數(shù)越大越能體現(xiàn)概率的準確性。每次前端頁面的請求,循環(huán)獎項設(shè)置數(shù)組,通過概率計算函數(shù)獲取抽中的獎項。
基本算法
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; }
這是一段經(jīng)典的概率算法,$proArr是一個預(yù)先設(shè)置的數(shù)組,假設(shè)數(shù)組為:array(100,200,300,400),開始是從1,1000這個概率范圍內(nèi)篩選第一個數(shù)是否在他的出現(xiàn)概率范圍之內(nèi), 如果不在,則將概率空減,也就是k的值減去剛剛的那個數(shù)字的概率空間,在本例當中就是減去100,也就是說第二個數(shù)是在1,900這個范圍內(nèi)篩選的。這樣篩選到最終,總會有一個數(shù)滿足要求。就相當于去一個箱子里摸東西,第一個不是,第二個不是,第三個還不是,那最后一個一定是。這個算法簡單,而且效率非常高,關(guān)鍵是這個算法已在我們以前的項目中有應(yīng)用,尤其是大數(shù)據(jù)量的項目中效率非常棒。
接下來我們通過PHP配置獎項。
$prize_arr = array( "0" => array("id"=>1,"prize"=>"平板電腦","v"=>1), "1" => array("id"=>2,"prize"=>"數(shù)碼相機","v"=>5), "2" => array("id"=>3,"prize"=>"音箱設(shè)備","v"=>10), "3" => array("id"=>4,"prize"=>"4G優(yōu)盤","v"=>12), "4" => array("id"=>5,"prize"=>"10Q幣","v"=>22), "5" => array("id"=>6,"prize"=>"下次沒準就能中哦","v"=>50), );
$prize_arr是一個二維數(shù)組,記錄了所有本次抽獎的獎項信息,其中id表示中獎等級,prize表示獎品,v表示中獎概率。注意其中的v必須為整數(shù),你可以將對應(yīng)的獎項的v設(shè)置成0,即意味著該獎項抽中的幾率是0,數(shù)組中v的總和(基數(shù)),基數(shù)越大越能體現(xiàn)概率的準確性。本例中v的總和為100,那么平板電腦對應(yīng)的中獎概率就是1%,如果v的總和是10000,那中獎概率就是萬分之一了。
每次前端頁面的請求,PHP循環(huán)獎項設(shè)置數(shù)組,通過概率計算函數(shù)get_rand獲取抽中的獎項id。將中獎獎品保存在數(shù)組$res[‘yes’]中,而剩下的未中獎的信息保存在$res[‘no’]中,最后輸出json個數(shù)數(shù)據(jù)給前端頁面。
//如果中獎數(shù)據(jù)是放在數(shù)據(jù)庫里,這里就需要進行判斷中獎數(shù)量 //在中1、2、3等獎的,如果達到最大數(shù)量的則unset相應(yīng)的獎項,避免重復(fù)中大獎 //code here eg:unset($prize_arr["0"]) foreach ($prize_arr as $key => $val) { $arr[$val["id"]] = $val["v"]; } $rid = get_rand($arr); //根據(jù)概率獲取獎項id $res["yes"] = $prize_arr[$rid-1]["prize"]; //中獎項 //將中獎項從數(shù)組中剔除,剩下未中獎項,如果是數(shù)據(jù)庫驗證,這里可以省掉 unset($prize_arr[$rid-1]); shuffle($prize_arr); //打亂數(shù)組順序 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); //根據(jù)概率獲取獎項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)); } } /* * 經(jīng)典的概率算法, * $proArr是一個預(yù)先設(shè)置的數(shù)組, * 假設(shè)數(shù)組為:array(100,200,300,400), * 開始是從1,1000 這個概率范圍內(nèi)篩選第一個數(shù)是否在他的出現(xiàn)概率范圍之內(nèi), * 如果不在,則將概率空間,也就是k的值減去剛剛的那個數(shù)字的概率空間, * 在本例當中就是減去100,也就是說第二個數(shù)是在1,900這個范圍內(nèi)篩選的。 * 這樣 篩選到最終,總會有一個數(shù)滿足要求。 * 就相當于去一個箱子里摸東西, * 第一個不是,第二個不是,第三個還不是,那最后一個一定是。 * 這個算法簡單,而且效率非常 高, * 關(guān)鍵是這個算法已在我們以前的項目中有應(yīng)用,尤其是大數(shù)據(jù)量的項目中效率非常棒。 */ 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; } //提交表單,手機號入庫 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,你已經(jīng)參加過此活動了!", ); exit(json_encode($data)); } }else{ $data = array( "code"=>"0", "msg"=>"手機號碼有誤,或驗證碼已經(jīng)過時,請核實!", ); 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"=>"對不起,該用戶已經(jīng)參加活動!", ); exit(json_encode($data)); }else{ $code = rand(1000,9999); $msg = "您好!你的驗證碼是:".$code.",請于10分鐘內(nèi)輸入驗證。"; $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"=>"發(fā)送成功!", "rest"=>$rest ); exit(json_encode($data)); } else { $data = array( "code"=>"0", "msg"=>"發(fā)送失?。?, "rest"=>$rest ); exit(json_encode($data)); } } } } //驗證手機號碼 public function isMobile($tel) { if(preg_match("/^1[34578]{1}d{9}$/",$tel)){ return true; }else{ return false; } } }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/22416.html
摘要:目錄如何用提高效率后端掘金經(jīng)常有人說我應(yīng)該學(xué)一門語言,比如之類,但是卻不知道如何入門。本文將通過我是如何開發(fā)公司年會抽獎系統(tǒng)的后端掘金需求出現(xiàn)年會將近,而年會抽獎環(huán)節(jié)必不可少,但是抽獎系統(tǒng)卻還沒有。 云盤一個個倒下怎么辦?無需編碼,手把手教你搭建至尊私享云盤 - 工具資源 - 掘金微盤掛了,360倒了,百度云盤也立了Flag。能讓我們在云端儲存分享文件的服務(wù)越來越少了。 買一堆移動硬盤...
摘要:演示下載地址效果圖三個金蛋一把錘子及中獎結(jié)果代碼如下錘子當鼠標滑向金蛋時,錘子會僅靠金蛋右上方,通過來控制位置。當揮動錘子砸向金蛋前,我們先把金蛋中的數(shù)字編號隱藏起來。最后,我們向后臺發(fā)送一個請求,后臺程序會處理獎項分配并把中獎結(jié)果返回。 演示下載地址:http://www.erdangjiade.com/js...效果圖:showImg(https://segmentfault.co...
摘要:演示下載地址效果圖三個金蛋一把錘子及中獎結(jié)果代碼如下錘子當鼠標滑向金蛋時,錘子會僅靠金蛋右上方,通過來控制位置。當揮動錘子砸向金蛋前,我們先把金蛋中的數(shù)字編號隱藏起來。最后,我們向后臺發(fā)送一個請求,后臺程序會處理獎項分配并把中獎結(jié)果返回。 演示下載地址:http://www.erdangjiade.com/js...效果圖:showImg(https://segmentfault.co...
摘要:演示下載地址效果圖三個金蛋一把錘子及中獎結(jié)果代碼如下錘子當鼠標滑向金蛋時,錘子會僅靠金蛋右上方,通過來控制位置。當揮動錘子砸向金蛋前,我們先把金蛋中的數(shù)字編號隱藏起來。最后,我們向后臺發(fā)送一個請求,后臺程序會處理獎項分配并把中獎結(jié)果返回。 演示下載地址:http://www.erdangjiade.com/js...效果圖:showImg(https://segmentfault.co...
閱讀 1216·2019-08-30 15:55
閱讀 964·2019-08-30 15:55
閱讀 2162·2019-08-30 15:44
閱讀 2895·2019-08-29 14:17
閱讀 1140·2019-08-29 12:45
閱讀 3316·2019-08-26 10:48
閱讀 3142·2019-08-23 18:18
閱讀 2613·2019-08-23 16:47