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