php機率演算法

來源:互聯網
上載者:User

標籤:

這是一個很經典的機率演算法函數:

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; }

假設:我們有這樣一個數組:a獎機率20%,b獎機率30%,c獎機率50%

$prize_arr =array(‘a‘=>20,‘b‘=>30,‘c‘=>50);

類比函數執行過程:

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

第一次數組迴圈,$procur=20

假設抽取的隨機數rand(1,100),假設抽到$randNum=55

if判斷-------

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

否則進入下一迴圈,總機率精度變為100-20=80

 


第二次數組迴圈,$procur=30

假設抽取的隨機數rand(1,80),假設抽到$randNum=33

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

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

否則進入下一迴圈,總機率精度變為80-30=50


第三次數組迴圈,$prosur=50;

假設抽取的隨機數rand(1,50),不管怎麼抽,隨機數都會<或=50,

那麼得出result=c;

 因為樣本沒有改變,雖然可能抽取的隨機數不止一個,但是機率是不變的。

 

 

或者也可以這樣:

    function get_rand($arr)    {        $pro_sum=array_sum($arr);        $rand_num=mt_rand(1,$pro_sum);        $tmp_num=0;        foreach($arr as $k=>$val)        {                if($rand_num<=$val+$tmp_num)            {                $n=$k;                break;            }else            {                $tmp_num+=$val;            }        }        return $n;    }

http://denghai260.blog.163.com/blog/static/7268640920128244332285/


php機率演算法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.