如何在php中取隨機數(shù)不重復?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
創(chuàng)新互聯(lián)公司網(wǎng)站建設公司,提供成都網(wǎng)站設計、做網(wǎng)站,網(wǎng)頁設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;可快速的進行網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,是專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!
php取隨機數(shù)不重復的方法:1、使用【rand(min,max)】函數(shù)產(chǎn)生隨機數(shù);2、使用【array_unique(arr)】對生成的數(shù)組進行去重;3、利用索引快速的生成不重復的隨機數(shù)。
php取隨機數(shù)不重復的方法:
首先想到的是rand(min,max)
函數(shù)產(chǎn)生隨機數(shù),實際上使用mt_rand(min,max)
能更加迅速的產(chǎn)生隨機數(shù)。
其次使用array_unique(arr)
對生成的數(shù)組進行去重,實際上使用array_flip(array_flip(arr))
能更加快速的進行去重。
了解以上兩點我們便可以寫一個稍微優(yōu)化過的函數(shù):
/** * 生成指定長度不重復的字符串. * * @param integer $min 最小值. * @param integer $max 最大值. * @param integer $len 生成數(shù)組長度. * * @return array */ function uniqueRandom($min, $max, $len) { if ($min < 0 || $max < 0 || $len) { throw new LogicException('無效的參數(shù)'); } if ($max <= $min) { throw new LogicException('大小傳入錯誤'); } $counter = 0; $result = array(); while ($counter < $len) { $result[] = mt_rand($min, $max); $result = array_flip(array_flip($result)); $counter = count($result); } shuffle($result); return $result; }
其實可以利用索引來更加快速的生成不重復的隨機數(shù),且效率甩上面函數(shù)幾條街。
/** * 生成指定長度不重復的字符串. * * @param integer $min 最小值. * @param integer $max 最大值. * @param integer $len 生成數(shù)組長度. * * @return array */ function uniqueRandom2($min, $max, $len) { if ($min < 0 || $max < 0 || $len < 0) { throw new LogicException('無效的參數(shù)'); } if ($max <= $min) { throw new LogicException('大小傳入錯誤'); } if (($max - $min + 2) < $len) { throw new LogicException("傳入的范圍不足以生成{$len}個不重復的隨機數(shù)}"); } $index = array(); for ($i = $min; $i < $max + 1; $i++) { $index[$i] = $i; } $startOne = current($index); $endOne = end($index); for ($i = $startOne; $i < $endOne; $i++) { $one = mt_rand($i, $max); if ($index[$i] == $i) { $index[$i] = $index[$one]; $index[$one] = $i; } } return array_slice($index, 0, $len); }
該算法與上面算法相比巧妙之處在于:
對自增索引進行隨機,不會有重復的問題,避免了去重的開銷
用數(shù)組下標替代數(shù)組本身進行隨機,每取到一個隨機數(shù)后就將其在取值范圍中排除,下一次僅會在剩下的數(shù)字中取,一次遍歷就可以完成隨機數(shù)的選取。
看完上述內(nèi)容,你們掌握如何在php中取隨機數(shù)不重復的方法了嗎?如果還想學到更多技能或想了解更多相關內(nèi)容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
網(wǎng)站名稱:如何在php中取隨機數(shù)不重復
本文鏈接:http://aaarwkj.com/article34/ipdgse.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、商城網(wǎng)站、電子商務、網(wǎng)站設計公司、做網(wǎng)站、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)