這篇文章給大家分享的內容是如何防止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中文網其他相關文章!