国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 php教程 php手冊 中獎概率算法(php可用于刮刮卡,大轉(zhuǎn)盤等抽獎算法)

中獎概率算法(php可用于刮刮卡,大轉(zhuǎn)盤等抽獎算法)

Jul 06, 2016 pm 01:30 PM
php 中獎 抽獎 機(jī)率 演算法 轉(zhuǎn)盤

php中獎概率算法,可用于刮刮卡,大轉(zhuǎn)盤等抽獎算法。用法很簡單,代碼里有詳細(xì)注釋說明,一看就懂 ? php /* * 經(jīng)典的概率算法, * $PRoArr是一個預(yù)先設(shè)置的數(shù)組, * 假設(shè)數(shù)組為:array(100,200,300,400), * 開始是從1,1000 這個概率范圍內(nèi)篩選第一個數(shù)是否

php中獎概率算法,可用于刮刮卡,大轉(zhuǎn)盤等抽獎算法。用法很簡單,代碼里有詳細(xì)注釋說明,一看就懂

<span style="color: #000000;">php
</span><span style="color: #008000;">/*</span><span style="color: #008000;">
 * 經(jīng)典的概率算法,
 * $PRoArr是一個預(yù)先設(shè)置的數(shù)組,
 * 假設(shè)數(shù)組為:array(100,200,300,400),
 * 開始是從1,1000 這個概率范圍內(nèi)篩選第一個數(shù)是否在他的出現(xiàn)概率范圍之內(nèi), 
 * 如果不在,則將概率空間,也就是k的值減去剛剛的那個數(shù)字的概率空間,
 * 在本例當(dāng)中就是減去100,也就是說第二個數(shù)是在1,900這個范圍內(nèi)篩選的。
 * 這樣 篩選到最終,總會有一個數(shù)滿足要求。
 * 就相當(dāng)于去一個箱子里摸東西,
 * 第一個不是,第二個不是,第三個還不是,那最后一個一定是。
 * 這個算法簡單,而且效率非常 高,
 * 關(guān)鍵是這個算法已在我們以前的項(xiàng)目中有應(yīng)用,尤其是大數(shù)據(jù)量的項(xiàng)目中效率非常棒。
 </span><span style="color: #008000;">*/</span>
<span style="color: #0000ff;">function</span> get_rand(<span style="color: #800080;">$proArr</span><span style="color: #000000;">) { 
    </span><span style="color: #800080;">$result</span> = ''<span style="color: #000000;">;  
    </span><span style="color: #008000;">//</span><span style="color: #008000;">概率數(shù)組的總概率精度 </span>
    <span style="color: #800080;">$proSum</span> = <span style="color: #008080;">array_sum</span>(<span style="color: #800080;">$proArr</span><span style="color: #000000;">);  
    </span><span style="color: #008000;">//</span><span style="color: #008000;">概率數(shù)組循環(huán) </span>
    <span style="color: #0000ff;">foreach</span> (<span style="color: #800080;">$proArr</span> <span style="color: #0000ff;">as</span> <span style="color: #800080;">$key</span> => <span style="color: #800080;">$proCur</span><span style="color: #000000;">) { 
        </span><span style="color: #800080;">$randNum</span> = <span style="color: #008080;">mt_rand</span>(1, <span style="color: #800080;">$proSum</span><span style="color: #000000;">); 
        </span><span style="color: #0000ff;">if</span> (<span style="color: #800080;">$randNum</span> $proCur<span style="color: #000000;">) { 
            </span><span style="color: #800080;">$result</span> = <span style="color: #800080;">$key</span><span style="color: #000000;">; 
            </span><span style="color: #0000ff;">break</span><span style="color: #000000;">; 
        } </span><span style="color: #0000ff;">else</span><span style="color: #000000;"> { 
            </span><span style="color: #800080;">$proSum</span> -= <span style="color: #800080;">$proCur</span><span style="color: #000000;">; 
        }         
    } 
    </span><span style="color: #0000ff;">unset</span> (<span style="color: #800080;">$proArr</span><span style="color: #000000;">);  
    </span><span style="color: #0000ff;">return</span> <span style="color: #800080;">$result</span><span style="color: #000000;">; 
} 


</span><span style="color: #008000;">/*</span><span style="color: #008000;">
 * 獎項(xiàng)數(shù)組
 * 是一個二維數(shù)組,記錄了所有本次抽獎的獎項(xiàng)信息,
 * 其中id表示中獎等級,prize表示獎品,v表示中獎概率。
 * 注意其中的v必須為整數(shù),你可以將對應(yīng)的 獎項(xiàng)的v設(shè)置成0,即意味著該獎項(xiàng)抽中的幾率是0,
 * 數(shù)組中v的總和(基數(shù)),基數(shù)越大越能體現(xiàn)概率的準(zhǔn)確性。
 * 本例中v的總和為100,那么平板電腦對應(yīng)的 中獎概率就是1%,
 * 如果v的總和是10000,那中獎概率就是萬分之一了。
 * 
 </span><span style="color: #008000;">*/</span>
<span style="color: #800080;">$prize_arr</span> = <span style="color: #0000ff;">array</span><span style="color: #000000;">( 
    </span>'0' => <span style="color: #0000ff;">array</span>('id'=>1,'prize'=>'平板電腦','v'=>1), 
    '1' => <span style="color: #0000ff;">array</span>('id'=>2,'prize'=>'數(shù)碼相機(jī)','v'=>5), 
    '2' => <span style="color: #0000ff;">array</span>('id'=>3,'prize'=>'音箱設(shè)備','v'=>10), 
    '3' => <span style="color: #0000ff;">array</span>('id'=>4,'prize'=>'4G優(yōu)盤','v'=>12), 
    '4' => <span style="color: #0000ff;">array</span>('id'=>5,'prize'=>'10Q幣','v'=>22), 
    '5' => <span style="color: #0000ff;">array</span>('id'=>6,'prize'=>'下次沒準(zhǔn)就能中哦','v'=>50),<span style="color: #000000;"> 
); 

</span><span style="color: #008000;">/*</span><span style="color: #008000;">
 * 每次前端頁面的請求,PHP循環(huán)獎項(xiàng)設(shè)置數(shù)組,
 * 通過概率計(jì)算函數(shù)get_rand獲取抽中的獎項(xiàng)id。
 * 將中獎獎品保存在數(shù)組$res['yes']中,
 * 而剩下的未中獎的信息保存在$res['no']中,
 * 最后輸出json個數(shù)數(shù)據(jù)給前端頁面。
 </span><span style="color: #008000;">*/</span>
<span style="color: #0000ff;">foreach</span> (<span style="color: #800080;">$prize_arr</span> <span style="color: #0000ff;">as</span> <span style="color: #800080;">$key</span> => <span style="color: #800080;">$val</span><span style="color: #000000;">) { 
    </span><span style="color: #800080;">$arr</span>[<span style="color: #800080;">$val</span>['id']] = <span style="color: #800080;">$val</span>['v'<span style="color: #000000;">]; 
} 
</span><span style="color: #800080;">$rid</span> = get_rand(<span style="color: #800080;">$arr</span>); <span style="color: #008000;">//</span><span style="color: #008000;">根據(jù)概率獲取獎項(xiàng)id </span>

<span style="color: #800080;">$res</span>['yes'] = <span style="color: #800080;">$prize_arr</span>[<span style="color: #800080;">$rid</span>-1]['prize']; <span style="color: #008000;">//</span><span style="color: #008000;">中獎項(xiàng) </span>
<span style="color: #0000ff;">unset</span>(<span style="color: #800080;">$prize_arr</span>[<span style="color: #800080;">$rid</span>-1]); <span style="color: #008000;">//</span><span style="color: #008000;">將中獎項(xiàng)從數(shù)組中剔除,剩下未中獎項(xiàng) </span>
<span style="color: #008080;">shuffle</span>(<span style="color: #800080;">$prize_arr</span>); <span style="color: #008000;">//</span><span style="color: #008000;">打亂數(shù)組順序 </span>
<span style="color: #0000ff;">for</span>(<span style="color: #800080;">$i</span>=0;<span style="color: #800080;">$i</span>count(<span style="color: #800080;">$prize_arr</span>);<span style="color: #800080;">$i</span>++<span style="color: #000000;">){ 
    </span><span style="color: #800080;">$pr</span>[] = <span style="color: #800080;">$prize_arr</span>[<span style="color: #800080;">$i</span>]['prize'<span style="color: #000000;">]; 
} 
</span><span style="color: #800080;">$res</span>['no'] = <span style="color: #800080;">$pr</span><span style="color: #000000;">; 
</span><span style="color: #008080;">print_r</span>(<span style="color: #800080;">$res</span>); 

?


本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何將兩個PHP陣列組合獨(dú)特的值? 如何將兩個PHP陣列組合獨(dú)特的值? Jul 02, 2025 pm 05:18 PM

要合併兩個PHP數(shù)組並保留唯一值,有兩種主要方法。 1.對於索引數(shù)組或僅需值去重的情況,使用array_merge和array_unique組合:先用array_merge($array1,$array2)合併數(shù)組,再用array_unique()去重,最終得到包含所有唯一值的新數(shù)組;2.對於關(guān)聯(lián)數(shù)組且希望保留第一個數(shù)組中的鍵值對時,使用 運(yùn)算符:$result=$array1 $array2,這將確保第一個數(shù)組中的鍵不會被第二個數(shù)組覆蓋。這兩種方法分別適用於不同場景,根據(jù)是否需要保留鍵名或只關(guān)注

如何使用PHP退出功能? 如何使用PHP退出功能? Jul 03, 2025 am 02:15 AM

exit()是PHP中用於立即終止腳本執(zhí)行的函數(shù),常見用途包括:1.在檢測到異常情況時提前終止腳本,如文件不存在或驗(yàn)證失敗;2.調(diào)試時輸出中間結(jié)果並停止執(zhí)行;3.結(jié)合header()重定向後調(diào)用exit()防止後續(xù)代碼執(zhí)行;此外,exit()可接受字符串參數(shù)作為輸出內(nèi)容或整數(shù)作為狀態(tài)碼,其別名為die()。

將語義結(jié)構(gòu)應(yīng)用於html的文章,部分和旁邊 將語義結(jié)構(gòu)應(yīng)用於html的文章,部分和旁邊 Jul 05, 2025 am 02:03 AM

在HTML中合理使用語義化標(biāo)籤能提升頁面結(jié)構(gòu)清晰度、可訪問性和SEO效果。 1.用於獨(dú)立內(nèi)容區(qū)塊,如博客文章或評論,需保持自包含性;2.用於歸類相關(guān)內(nèi)容,通常包含標(biāo)題,適用於頁面不同模塊;3.用於與主內(nèi)容相關(guān)但非核心的輔助信息,如側(cè)邊欄推薦或作者簡介。實(shí)際開發(fā)中應(yīng)結(jié)合、等標(biāo)籤,避免過度嵌套,保持結(jié)構(gòu)簡潔,並通過開發(fā)者工具驗(yàn)證結(jié)構(gòu)合理性。

如何在PHP中創(chuàng)建數(shù)組? 如何在PHP中創(chuàng)建數(shù)組? Jul 02, 2025 pm 05:01 PM

在PHP中創(chuàng)建數(shù)組的方法有兩種:使用array()函數(shù)或使用中括號[]。 1.使用array()函數(shù)是傳統(tǒng)方式,兼容性好,定義索引數(shù)組如$fruits=array("apple","banana","orange"),關(guān)聯(lián)數(shù)組如$user=array("name"=>"John","age"=>25);2.使用[]是從PHP5.4開始支持的更簡潔的方式,如$color

請求的操作需要高程窗戶 請求的操作需要高程窗戶 Jul 04, 2025 am 02:58 AM

遇到“此操作需要提升權(quán)限”提示時,說明你需要管理員權(quán)限才能繼續(xù)。解決方法包括:1.右鍵選擇“以管理員身份運(yùn)行”程序或設(shè)置快捷方式始終以管理員身份運(yùn)行;2.檢查當(dāng)前賬戶是否為管理員賬戶,若不是則切換或請求管理員協(xié)助;3.用管理員權(quán)限打開命令提示符或PowerShell執(zhí)行相關(guān)命令;4.在必要時通過獲取文件所有權(quán)或修改註冊表等手段繞過限制,但此類操作需謹(jǐn)慎並充分了解風(fēng)險(xiǎn)。確認(rèn)權(quán)限身份並嘗試上述方法通??山鉀Q問題。

PHP原始帖子數(shù)據(jù)PHP PHP原始帖子數(shù)據(jù)PHP Jul 02, 2025 pm 04:51 PM

在PHP中處理原始POST數(shù)據(jù)的方法是使用$rawData=file_get_contents('php://input'),適用於接收J(rèn)SON、XML或其他自定義格式數(shù)據(jù)。 1.php://input是一個只讀流,僅在POST請求中有效;2.常見問題包括服務(wù)器配置或中間件已讀取輸入流導(dǎo)致無法獲取數(shù)據(jù);3.應(yīng)用場景包括接收前端fetch請求、第三方服務(wù)回調(diào)和構(gòu)建RESTfulAPI;4.與$_POST的區(qū)別在於$_POST自動解析標(biāo)準(zhǔn)表單數(shù)據(jù),而原始數(shù)據(jù)適合非標(biāo)準(zhǔn)格式並允許手動解析;5.普通HTM

如何在PHP中牢固地處理文件上傳? 如何在PHP中牢固地處理文件上傳? Jul 08, 2025 am 02:37 AM

要安全處理PHP文件上傳需驗(yàn)證來源與類型、控製文件名與路徑、設(shè)置服務(wù)器限制並二次處理媒體文件。 1.驗(yàn)證上傳來源通過token防止CSRF並通過finfo_file檢測真實(shí)MIME類型使用白名單控制;2.重命名文件為隨機(jī)字符串並根據(jù)檢測類型決定擴(kuò)展名存儲至非Web目錄;3.PHP配置限制上傳大小及臨時目錄Nginx/Apache禁止訪問上傳目錄;4.GD庫重新保存圖片清除潛在惡意數(shù)據(jù)。

您如何按值與PHP中的參考傳遞變量? 您如何按值與PHP中的參考傳遞變量? Jul 08, 2025 am 02:42 AM

InPHP,variablesarepassedbyvaluebydefault,meaningfunctionsorassignmentsreceiveacopyofthedata,whilepassingbyreferenceallowsmodificationstoaffecttheoriginalvariable.1.Whenpassingbyvalue,changestothecopydonotimpacttheoriginal,asshownwhenassigning$b=$aorp

See all articles