思路:將生成的隨機(jī)數(shù)存入數(shù)組,再在數(shù)組中去除重復(fù)的值,即可生成一定數(shù)量的不重復(fù)隨機(jī)數(shù)。
在PHP網(wǎng)站開發(fā)中,有時(shí)候我們需要生成指定范圍內(nèi)一定數(shù)量的不重復(fù)隨機(jī)數(shù),具體怎么設(shè)計(jì)這個(gè)生產(chǎn)隨機(jī)數(shù)的函數(shù)呢?我們可以將隨機(jī)產(chǎn)生的數(shù)存入數(shù)組,但在存入的同時(shí)去除重復(fù)的值,即可生成一定數(shù)量的不重復(fù)隨機(jī)數(shù)。當(dāng)然也可以把指定范圍內(nèi)的數(shù)值存進(jìn)數(shù)組,再使用shuffle($array)
打亂這個(gè)數(shù)組,然后再截取其中一定數(shù)量的值。但后面的一種做法在指定的隨機(jī)數(shù)范圍太大的時(shí)候會(huì)產(chǎn)生一個(gè)較大的數(shù)組。
下面給出第一種做法的代碼,第二種做法更簡(jiǎn)單,大家可以嘗試下,其實(shí)也差不多
?php
/*
* array unique_rand( int $min, int $max, int $num )
* 生成一定數(shù)量的不重復(fù)隨機(jī)數(shù),指定的范圍內(nèi)整數(shù)的數(shù)量必須
* 比要生成的隨機(jī)數(shù)數(shù)量大
* $min 和 $max: 指定隨機(jī)數(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個(gè)1到100范圍內(nèi)的不重復(fù)隨機(jī)數(shù)
$arr = unique_rand(1, 100, 10);
echo implode($arr, ",");
?>
程序運(yùn)行如下:
48,5,19,36,63,72,82,77,46,16
補(bǔ)充幾點(diǎn)說(shuō)明:
1、生成隨機(jī)數(shù)時(shí)我們用了 mt_rand()
函數(shù)。這個(gè)函數(shù)生成隨機(jī)數(shù)的平均速度要比 rand()
快幾倍。
2、去除數(shù)組中的重復(fù)值時(shí)用了“翻轉(zhuǎn)法”,就是用 array_flip()
把數(shù)組的 key 和 value 交換兩次。這種做法在去除數(shù)組重復(fù)值的同時(shí)效率也比用 array_unique()
快得多。
3、返回?cái)?shù)組前,先使用 shuffle()
為數(shù)組賦予新的鍵名,保證鍵名是 0-n 連續(xù)的數(shù)字。如果不進(jìn)行此步驟,可能在刪除重復(fù)值時(shí)造成鍵名不連續(xù),如果用for遍歷的時(shí)候會(huì)有問(wèn)題,但如果用foreach或不需要遍歷的時(shí)候可以不需要shuffle。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
您可能感興趣的文章:- PHP內(nèi)置函數(shù)生成隨機(jī)數(shù)實(shí)例
- php簡(jiǎn)單生成隨機(jī)數(shù)的方法
- php生成不重復(fù)隨機(jī)數(shù)、數(shù)組的4種方法分享
- PHP生成不重復(fù)隨機(jī)數(shù)的方法匯總
- php生成隨機(jī)數(shù)的三種方法
- PHP生成指定長(zhǎng)度隨機(jī)數(shù)最簡(jiǎn)潔的方法
- 在PHP模板引擎smarty生成隨機(jī)數(shù)的方法和math函數(shù)詳解
- 如何在PHP中生成隨機(jī)數(shù)