php 生成N個(gè)不重復(fù)的隨機(jī)數(shù)實(shí)例詳解
來(lái)源:程序員人生 發(fā)布時(shí)間:2014-03-31 02:34:32 閱讀次數(shù):3022次
生成隨機(jī)數(shù)時(shí)用了mt_rand() 函數(shù),這個(gè)函數(shù)生成隨機(jī)數(shù)的平均速度要比 rand() 快四倍。
去除數(shù)組中的重復(fù)值時(shí)用了“翻翻法”,就是用 array_flip() 把數(shù)組的 key 和 value 交換兩次,這種做法比用 array_unique() 快得多。
返回?cái)?shù)組前,先使用 shuffle() 為數(shù)組賦予新的鍵名,保證鍵名是 0-n 連續(xù)的數(shù)字,如果不進(jìn)行此步驟,可能在刪除重復(fù)值時(shí)造成鍵名不連續(xù),給遍歷帶來(lái)麻煩,實(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);
- }
- shuffle($return);
- return $return;
- }
生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對(duì)您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈(zèng)