PHP 產生N個不重複的隨機數,php產生n隨機數_PHP教程

來源:互聯網
上載者:User

PHP 產生N個不重複的隨機數,php產生n隨機數


起因:

有25幅作品拿去投票,一次投票需要選16幅,單個作品一次投票只能選擇一次。前面有個程式員捅了漏子,忘了把投票入庫,有200個使用者產生的投票序列為空白。那麼你會如何填補這個漏子?

當然向上級反映情況。但是我們這裡討論的是技術,就是需要產生1-25之間的16個不重複的隨機數,去填補。具體怎麼設計函數呢?將隨機數存入數組,再在數組中去除重複的值,即可產生一定數量的不重複隨機數。

程式如下:

複製代碼 代碼如下:
<?php
/*
* array unique_rand( int $min, int $max, int $num )
* 產生一定數量的不重複隨機數
* $min 和 $max: 指定隨機數的範圍
* $num: 指定產生數量
*/
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

補充幾點說明:

產生隨機數時用了 mt_rand() 函數。這個函數產生隨機數的平均速度要比 rand() 快四倍。
去除數組中的重複值時用了“翻翻法”,就是用 array_flip() 把數組的 key 和 value 交換兩次。這種做法比用 array_unique() 快得多。
返回數組前,先使用 shuffle() 為數組賦予新的鍵名,保證鍵名是 0-n 連續的數字。如果不進行此步驟,可能在重複資料刪除值時造成鍵名不連續,給遍曆帶來麻煩。

http://www.bkjia.com/PHPjc/945704.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/945704.htmlTechArticlePHP 產生N個不重複的隨機數,php產生n隨機數 起因: 有25幅作品拿去投票,一次投票需要選16幅,單個作品一次投票只能選擇一次。前面有個...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.