php生成N個不重復的隨機數(shù)實例
有25幅作品拿去投票,一次投票需要選16幅,單個作品一次投票只能選擇一次。前面有個程序員捅了漏子,忘了把投票入庫,有200個用戶產(chǎn)生的投票序列為空。那么你會如何填補這個漏子?
當然向上級反映情況。但是我們這里討論的是技術,就是需要生成1-25之間的16個不重復的隨機數(shù),去填補。具體怎么設計函數(shù)呢?將隨機數(shù)存入數(shù)組,再在數(shù)組中去除重復的值,即可生成一定數(shù)量的不重復隨機數(shù)。
程序如下:
<?php
/*
* array unique_rand( int $min, int $max, int $num )
* 生成一定數(shù)量的不重復隨機數(shù)
* $min 和 $max: 指定隨機數(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);
}
shuffle($return);
return $return;
}
$arr = unique_rand(1, 25, 16);
sort($arr);
$result = '';
for($i=0; $i < count($arr);$i++)
{
$result .= $arr[$i].',';
}
$result = substr($result, 0, -1);
echo $result;
?>
程序運行如下:
2,3,4,6,7,8,9,10,11,12,13,16,20,21,22,24
補充幾點說明:
生成隨機數(shù)時用了 mt_rand() 函數(shù)。這個函數(shù)生成隨機數(shù)的平均速度要比 rand() 快四倍。
去除數(shù)組中的重復值時用了“翻翻法”,就是用 array_flip() 把數(shù)組的 key 和 value 交換兩次。這種做法比用 array_unique() 快得多。
返回數(shù)組前,先使用 shuffle() 為數(shù)組賦予新的鍵名,保證鍵名是 0-n 連續(xù)的數(shù)字。如果不進行此步驟,可能在刪除重復值時造成鍵名不連續(xù),給遍歷帶來麻煩。
- php生成隨機數(shù)的三種方法
- PHP生成不重復隨機數(shù)的方法匯總
- PHP n個不重復的隨機數(shù)生成代碼
- PHP生成指定長度隨機數(shù)最簡潔的方法
- PHP產(chǎn)生不重復隨機數(shù)的5個方法總結
- php獲取四位字母和數(shù)字的隨機數(shù)的實現(xiàn)方法
- 一個php生成16位隨機數(shù)的代碼(兩種方法)
- 深入PHP獲取隨機數(shù)字和字母的方法詳解
- PHP的偽隨機數(shù)與真隨機數(shù)詳解
- PHP 生成N個不重復的隨機數(shù)
- php生成不重復隨機數(shù)、數(shù)組的4種方法分享
- PHP隨機數(shù)生成代碼與使用實例分析
- PHP簡單獲取隨機數(shù)的常用方法小結
相關文章
使用PHP備份MySQL和網(wǎng)站發(fā)送到郵箱實例代碼
這篇文章主要介紹了使用PHP備份MySQL和網(wǎng)站發(fā)送到郵箱的方法,大家參考使用吧2013-11-11PHP?ceil()函數(shù)浮點數(shù)向上取整實現(xiàn)示例
這篇文章主要為大家介紹了PHP?ceil()函數(shù)實現(xiàn)浮點數(shù)向上取整示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01利用PHP?POST臨時文件機制實現(xiàn)任意文件上傳的方法詳解
這篇文章主要介紹了利用?PHP?POST?臨時文件機制實現(xiàn)任意文件上傳,同時該過程也會打斷 php 對臨時文件的處理,雖然最終仍會被刪除,但相較之前可以明顯看出臨時文件在磁盤的中存在的時間變長了,需要的朋友可以參考下2022-04-04php守護進程 加linux命令nohup實現(xiàn)任務每秒執(zhí)行一次
那么有了這個命令以后我們php就寫成shell 腳本使用循環(huán)來讓我們腳本一直運行下去,不管我們終端窗口是否關閉都能夠讓我們php 腳本一直運行下去。2011-07-07