首頁 >後端開發 >php教程 >PHP中生產不重複隨機數的方法

PHP中生產不重複隨機數的方法

不言
不言原創
2018-04-09 17:51:161955瀏覽

本文主要和大家分享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隨機數所產生的rand()函數

php隨機數不重複產生的五種方式

由數字字母產生php隨機數的方法

以上是PHP中生產不重複隨機數的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn