PHP生成指定范圍內(nèi)的N個不重復(fù)的隨機數(shù)
思路:將生成的隨機數(shù)存入數(shù)組,再在數(shù)組中去除重復(fù)的值,即可生成一定數(shù)量的不重復(fù)隨機數(shù)。
在PHP網(wǎng)站開發(fā)中,有時候我們需要生成指定范圍內(nèi)一定數(shù)量的不重復(fù)隨機數(shù),具體怎么設(shè)計這個生產(chǎn)隨機數(shù)的函數(shù)呢?我們可以將隨機產(chǎn)生的數(shù)存入數(shù)組,但在存入的同時去除重復(fù)的值,即可生成一定數(shù)量的不重復(fù)隨機數(shù)。當(dāng)然也可以把指定范圍內(nèi)的數(shù)值存進(jìn)數(shù)組,再使用shuffle($array)
打亂這個數(shù)組,然后再截取其中一定數(shù)量的值。但后面的一種做法在指定的隨機數(shù)范圍太大的時候會產(chǎn)生一個較大的數(shù)組。
下面給出第一種做法的代碼,第二種做法更簡單,大家可以嘗試下,其實也差不多
<?php /* * array unique_rand( int $min, int $max, int $num ) * 生成一定數(shù)量的不重復(fù)隨機數(shù),指定的范圍內(nèi)整數(shù)的數(shù)量必須 * 比要生成的隨機數(shù)數(shù)量大 * $min 和 $max: 指定隨機數(shù)的范圍 * $num: 指定生成數(shù)量 */ function unique_rand($min, $max, $num) { $count = 0; $return = array(); while ($count < $num) { $return[] = mt_rand($min, $max); $return = array_flip(array_flip($return)); $count = count($return); } //打亂數(shù)組,重新賦予數(shù)組新的下標(biāo) shuffle($return); return $return; } //生成10個1到100范圍內(nèi)的不重復(fù)隨機數(shù) $arr = unique_rand(1, 100, 10); echo implode($arr, ","); ?>
程序運行如下:
48,5,19,36,63,72,82,77,46,16
補充幾點說明:
1、生成隨機數(shù)時我們用了 mt_rand()
函數(shù)。這個函數(shù)生成隨機數(shù)的平均速度要比 rand()
快幾倍。
2、去除數(shù)組中的重復(fù)值時用了“翻轉(zhuǎn)法”,就是用 array_flip()
把數(shù)組的 key 和 value 交換兩次。這種做法在去除數(shù)組重復(fù)值的同時效率也比用 array_unique()
快得多。
3、返回數(shù)組前,先使用 shuffle()
為數(shù)組賦予新的鍵名,保證鍵名是 0-n 連續(xù)的數(shù)字。如果不進(jìn)行此步驟,可能在刪除重復(fù)值時造成鍵名不連續(xù),如果用for遍歷的時候會有問題,但如果用foreach或不需要遍歷的時候可以不需要shuffle。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
PHP基于PDO實現(xiàn)的SQLite操作類【包含增刪改查及事務(wù)等操作】
這篇文章主要介紹了PHP基于PDO實現(xiàn)的SQLite操作類,包含增刪改查及事務(wù)等操作實現(xiàn)技巧與使用方法,需要的朋友可以參考下2017-06-06

PHP中filter函數(shù)校驗數(shù)據(jù)的方法詳解

php中debug_backtrace、debug_print_backtrace和匿名函數(shù)用法實例

Notice: Undefined index: page in E:\PHP\test.php on line 14