php取不重複隨機數的方法:首先透過「mt_random($min,$max)」方法隨機取區間內的一個值;然後透過兩次「key-value」交換來實現不重複的隨機數字即可。
推薦:《PHP影片教學》
PHP中生產不重複隨機數的方法
PHP內建函數不重複隨機數
需求:要產生一個陣列,這個陣列裡面有10個元素,都是整形,並且是1- 60之間不重複的隨機數。
程式碼:
程式碼範例:
<?php function get_randoms($min,$max,$num){ $count = 0; $res = array(); while($count<$num){ $res[] = mt_random($min,$max); $res = array_flip(array_flip($res)); $count = count($res); } return $res; } $result = get_randoms(1,60,10); ?>
#
在這裡他用$count 結果陣列的個數,他在while 迴圈中使得結果陣列的個數小於目標個數。透過這樣,取得到$count 是 目標個數 的一個陣列。
期間,每一個循環中,透過mt_random($min,$max),隨機出區間內的一個值,存放到數組$res中,然後透過兩次key-value 交換,也就是透過數組key的唯一性,使得做到不重複。
我看了這個邏輯的程式碼之後,我不禁陷入了深思,假如說當你不知道array_filp 函數的時候你怎麼做?
說白了就是用key的唯一性,使得隨機數不會有重複。那我們能不能將這個問題簡單化處理呢?
程式碼範例:
<?php function get_randoms($min,$max,$num){ $count = 0; $res = array(); while($count<$num){ $key = mt_random($min,$max); $res[$key] = $key; $count = count($res); } return $res; } $result = get_randoms(1,60,10); ?>
這樣完全是單獨的透過陣列key的唯一性 解決了這個問題。根本就不會用到array_flip。
總結:
1,因為php提供了大量的內建函數,他們的執行效率都很高。在遇到問題的時候,盡可能去用它來解決問題。這樣方便又快速。
2,php 提供了大量的內建函數,執行效率也很高,但是,雖然效率高,還是需要時間去執行的。
在遇到問題的時候,不要盲目的去做,可以先看清處理方法的本質,以便於巧妙的實現他。
以上是php如何取不重複的隨機數的詳細內容。更多資訊請關注PHP中文網其他相關文章!