《PHP應(yīng)用:PHP 生成N個(gè)不重復(fù)的隨機(jī)數(shù)》要點(diǎn):
本文介紹了PHP應(yīng)用:PHP 生成N個(gè)不重復(fù)的隨機(jī)數(shù),希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
PHP實(shí)例起因:
PHP實(shí)例有25幅作品拿去投票,一次投票必要選16幅,單個(gè)作品一次投票只能選擇一次.前面有個(gè)程序員捅了漏子,忘了把投票入庫(kù),有200個(gè)用戶產(chǎn)生的投票序列為空.那么你會(huì)如何填補(bǔ)這個(gè)漏子?
PHP實(shí)例當(dāng)然向上級(jí)反映情況.但是我們這里討論的是技術(shù),就是需要生成1-25之間的16個(gè)不重復(fù)的隨機(jī)數(shù),去填補(bǔ).具體怎么設(shè)計(jì)函數(shù)呢?將隨機(jī)數(shù)存入數(shù)組,再在數(shù)組中去除重復(fù)的值,即可生成必定數(shù)量的不重復(fù)隨機(jī)數(shù).
PHP實(shí)例程序如下:
PHP實(shí)例程序運(yùn)行如下:
PHP實(shí)例補(bǔ)充幾點(diǎn)說(shuō)明:
PHP實(shí)例生成隨機(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)麻煩.
《PHP應(yīng)用:PHP 生成N個(gè)不重復(fù)的隨機(jī)數(shù)》是否對(duì)您有啟發(fā),歡迎查看更多與《PHP應(yīng)用:PHP 生成N個(gè)不重復(fù)的隨機(jī)數(shù)》相關(guān)教程,學(xué)精學(xué)透。維易PHP學(xué)院為您提供精彩教程。
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/12594.html