国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > PHP > 正文

PHP概率計(jì)算函數(shù)匯總

2024-05-04 23:39:01
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

做項(xiàng)目的有時(shí)會(huì)弄個(gè)活動(dòng)什么的,來(lái)讓用戶參加,既吸引用戶注冊(cè),又提高網(wǎng)站的用戶活躍度。同時(shí)參加的用戶會(huì)獲得一定的獎(jiǎng)品,有100%中獎(jiǎng)的,也有按一定概率中獎(jiǎng)的,大的比如中個(gè)ipad,小的中個(gè)Q幣。那么我們?cè)诔绦蚶锉厝粫?huì)設(shè)計(jì)到算法,即按照一定的概率讓用戶獲得獎(jiǎng)品。

其實(shí)發(fā)這篇博感覺(jué)并沒(méi)有什么用,太簡(jiǎn)單了,會(huì)的人不屑看,不會(huì)的人自已動(dòng)動(dòng)腦子也想到了。但是看著自已的博客已經(jīng)這么久沒(méi)更,真心疼~。粗略算下一篇只有代碼的水文,會(huì)占用OSC至少十幾KB的數(shù)據(jù)庫(kù)空間呢,但是,一想到亂彈里的然并卵,也就釋然了。

 

 
  1. <?php 
  2.  
  3. /** 
  4. * 概率計(jì)算類 
  5. * 可用于抽獎(jiǎng)等 
  6. */ 
  7. class Probability 
  8. /** 
  9. * 概率統(tǒng)計(jì)數(shù)據(jù) 
  10. * thing => chance 
  11. */ 
  12. var $data = array(); 
  13. var $chance_count = 0; 
  14.  
  15. function __construct($initdata = array()){ 
  16. if(!empty($initdata)){ 
  17. $this->data = $initdata; 
  18. foreach($initdata as $d){ 
  19. $this->chance_count += $d['num']; 
  20.  
  21. function addData($name, $chance){ 
  22. $this->data[]=array('name'=>$name, 'num'=>$chance); 
  23. $this->chance_count += $chance; 
  24.  
  25. function getOne(){ 
  26. $index = rand(0, $this->chance_count); 
  27. foreach($this->data as $d){ 
  28. $index = $index-$d['num']; 
  29. if($index<=0){ 
  30. return $d['name']; 
  31. return ''
  32.  
  33.  
  34. /** 
  35. * 使用示例 
  36. */ 
  37. $pro=new Probability(); 
  38. $pro->addData('iphone',10); 
  39. $pro->addData('watch',30); 
  40. $pro->addData('$18',50); 
  41. $pro->addData('thank you',10); 
  42. $pro->addData('super big',1); 
  43. for($i=0;$i<100;$i++){ 
  44. echo $pro->getOne()."/n"

這是一個(gè)很經(jīng)典的概率算法函數(shù):

 

 
  1. function get_rand($proArr) {  
  2. $result = '';  
  3. //概率數(shù)組的總概率精度  
  4. $proSum = array_sum($proArr);  
  5. //概率數(shù)組循環(huán)  
  6. foreach ($proArr as $key => $proCur) {  
  7. $randNum = mt_rand(1, $proSum); //抽取隨機(jī)數(shù) 
  8. if ($randNum <= $proCur) {  
  9. $result = $key; //得出結(jié)果 
  10. break;  
  11. else {  
  12. $proSum -= $proCur;  
  13. }  
  14. }  
  15. unset ($proArr);  
  16. return $result;  

假設(shè):我們有這樣一個(gè)數(shù)組:a獎(jiǎng)概率20%,b獎(jiǎng)概率30%,c獎(jiǎng)概率50%

 

 
  1. $prize_arr =array('a'=>20,'b'=>30,'c'=>50); 

模擬函數(shù)執(zhí)行過(guò)程:

總概率精度為20+30+50=100

第一次數(shù)組循環(huán),$procur=20

假設(shè)抽取的隨機(jī)數(shù)rand(1,100),假設(shè)抽到$randNum=55

if判斷-------

如果$randNum<=20,則result=a

否則進(jìn)入下一循環(huán),總概率精度變?yōu)?00-20=80

第二次數(shù)組循環(huán),$procur=30

假設(shè)抽取的隨機(jī)數(shù)rand(1,80),假設(shè)抽到$randNum=33

if判斷---------

如果$randNum<=30,則result=b

否則進(jìn)入下一循環(huán),總概率精度變?yōu)?0-30=50

第三次數(shù)組循環(huán),$prosur=50;

假設(shè)抽取的隨機(jī)數(shù)rand(1,50),不管怎么抽,隨機(jī)數(shù)都會(huì)<或=50,

那么得出result=c;

因?yàn)闃颖緵](méi)有改變,雖然可能抽取的隨機(jī)數(shù)不止一個(gè),但是概率是不變的。

或者也可以這樣:

 

 
  1. function get_rand($arr) 
  2. $pro_sum=array_sum($arr); 
  3. $rand_num=mt_rand(1,$pro_sum); 
  4. $tmp_num=0; 
  5. foreach($arr as $k=>$val) 
  6. {  
  7. if($rand_num<=$val+$tmp_num) 
  8. $n=$k; 
  9. break
  10. }else 
  11. $tmp_num+=$val; 
  12. return $n; 

在給大家分享一個(gè)抽獎(jiǎng)的概率算法

 

 
  1. /* 
  2. * 經(jīng)典的概率算法, 
  3. * $proArr是一個(gè)預(yù)先設(shè)置的數(shù)組, 
  4. * 假設(shè)數(shù)組為:array(100,200,300,400), 
  5. * 開(kāi)始是從1,1000 這個(gè)概率范圍內(nèi)篩選第一個(gè)數(shù)是否在他的出現(xiàn)概率范圍之內(nèi),  
  6. * 如果不在,則將概率空間,也就是k的值減去剛剛的那個(gè)數(shù)字的概率空間, 
  7. * 在本例當(dāng)中就是減去100,也就是說(shuō)第二個(gè)數(shù)是在1,900這個(gè)范圍內(nèi)篩選的。 
  8. * 這樣 篩選到最終,總會(huì)有一個(gè)數(shù)滿足要求。 
  9. * 就相當(dāng)于去一個(gè)箱子里摸東西, 
  10. * 第一個(gè)不是,第二個(gè)不是,第三個(gè)還不是,那最后一個(gè)一定是。 
  11. * 這個(gè)算法簡(jiǎn)單,而且效率非常 高, 
  12. * 關(guān)鍵是這個(gè)算法已在我們以前的項(xiàng)目中有應(yīng)用,尤其是大數(shù)據(jù)量的項(xiàng)目中效率非常棒。 
  13. */ 
  14. function get_rand($proArr) { 
  15. $result = ''
  16. //概率數(shù)組的總概率精度  
  17. $proSum = array_sum($proArr); 
  18. //概率數(shù)組循環(huán)  
  19. foreach ($proArr as $key => $proCur) { 
  20. $randNum = mt_rand(1, $proSum); 
  21. if ($randNum <= $proCur) { 
  22. $result = $key; 
  23. break
  24. else { 
  25. $proSum -= $proCur; 
  26. unset ($proArr); 
  27. return $result; 
  28.  
  29.  
  30. /* 
  31. * 獎(jiǎng)項(xiàng)數(shù)組 
  32. * 是一個(gè)二維數(shù)組,記錄了所有本次抽獎(jiǎng)的獎(jiǎng)項(xiàng)信息, 
  33. * 其中id表示中獎(jiǎng)等級(jí),prize表示獎(jiǎng)品,v表示中獎(jiǎng)概率。 
  34. * 注意其中的v必須為整數(shù),你可以將對(duì)應(yīng)的 獎(jiǎng)項(xiàng)的v設(shè)置成0,即意味著該獎(jiǎng)項(xiàng)抽中的幾率是0, 
  35. * 數(shù)組中v的總和(基數(shù)),基數(shù)越大越能體現(xiàn)概率的準(zhǔn)確性。 
  36. * 本例中v的總和為100,那么平板電腦對(duì)應(yīng)的 中獎(jiǎng)概率就是1%, 
  37. * 如果v的總和是10000,那中獎(jiǎng)概率就是萬(wàn)分之一了。 
  38.  
  39. */ 
  40. $prize_arr = array( 
  41. '0' => array('id'=>1,'prize'=>'平板電腦','v'=>1), 
  42. '1' => array('id'=>2,'prize'=>'數(shù)碼相機(jī)','v'=>5), 
  43. '2' => array('id'=>3,'prize'=>'音箱設(shè)備','v'=>10), 
  44. '3' => array('id'=>4,'prize'=>'4G優(yōu)盤(pán)','v'=>12), 
  45. '4' => array('id'=>5,'prize'=>'10Q幣','v'=>22), 
  46. '5' => array('id'=>6,'prize'=>'下次沒(méi)準(zhǔn)就能中哦','v'=>50), 
  47. ); 
  48.  
  49. /* 
  50. * 每次前端頁(yè)面的請(qǐng)求,PHP循環(huán)獎(jiǎng)項(xiàng)設(shè)置數(shù)組, 
  51. * 通過(guò)概率計(jì)算函數(shù)get_rand獲取抽中的獎(jiǎng)項(xiàng)id。 
  52. * 將中獎(jiǎng)獎(jiǎng)品保存在數(shù)組$res['yes']中, 
  53. * 而剩下的未中獎(jiǎng)的信息保存在$res['no']中, 
  54. * 最后輸出json個(gè)數(shù)數(shù)據(jù)給前端頁(yè)面。 
  55. */ 
  56. foreach ($prize_arr as $key => $val) { 
  57. $arr[$val['id']] = $val['v']; 
  58. $rid = get_rand($arr); //根據(jù)概率獲取獎(jiǎng)項(xiàng)id  
  59.  
  60. $res['yes'] = $prize_arr[$rid-1]['prize']; //中獎(jiǎng)項(xiàng)  
  61. unset($prize_arr[$rid-1]); //將中獎(jiǎng)項(xiàng)從數(shù)組中剔除,剩下未中獎(jiǎng)項(xiàng)  
  62. shuffle($prize_arr); //打亂數(shù)組順序  
  63. for($i=0;$i<count($prize_arr);$i++){ 
  64. $pr[] = $prize_arr[$i]['prize']; 
  65. $res['no'] = $pr; 
  66. print_r($res['yes']); 

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 尉犁县| 固阳县| 嫩江县| 临泽县| 承德市| 冀州市| 五峰| 桂林市| 兴海县| 武汉市| 怀仁县| 平南县| 洮南市| 河北区| 南城县| 高陵县| 大石桥市| 灌阳县| 自贡市| 平凉市| 内黄县| 永城市| 蕲春县| 栾川县| 景德镇市| 溧阳市| 普安县| 驻马店市| 沁源县| 鄄城县| 平谷区| 郎溪县| 清涧县| 沈阳市| 舒城县| 抚远县| 大丰市| 西乌珠穆沁旗| 苗栗县| 琼结县| 商城县|