思路:將生成的隨機(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)說明:
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ì)有問題,但如果用foreach或不需要遍歷的時(shí)候可以不需要shuffle。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
標(biāo)簽:九江 昭通 十堰 梅河口 甘肅 遼陽(yáng) 韶關(guān) 涼山
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP生成指定范圍內(nèi)的N個(gè)不重復(fù)的隨機(jī)數(shù)》,本文關(guān)鍵詞 PHP,生成,指定,范圍內(nèi),的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。