亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

php生成N個(gè)不重復(fù)的隨機(jī)數(shù)實(shí)例

 更新時(shí)間:2013年11月12日 09:27:03   作者:  
使用php生成N個(gè)不重復(fù)的隨機(jī)數(shù)的實(shí)例方法

有25幅作品拿去投票,一次投票需要選16幅,單個(gè)作品一次投票只能選擇一次。前面有個(gè)程序員捅了漏子,忘了把投票入庫(kù),有200個(gè)用戶產(chǎn)生的投票序列為空。那么你會(huì)如何填補(bǔ)這個(gè)漏子?
當(dāng)然向上級(jí)反映情況。但是我們這里討論的是技術(shù),就是需要生成1-25之間的16個(gè)不重復(fù)的隨機(jī)數(shù),去填補(bǔ)。具體怎么設(shè)計(jì)函數(shù)呢?將隨機(jī)數(shù)存入數(shù)組,再在數(shù)組中去除重復(fù)的值,即可生成一定數(shù)量的不重復(fù)隨機(jī)數(shù)。
程序如下:

復(fù)制代碼 代碼如下:

<?php
/*
* array unique_rand( int $min, int $max, int $num )
* 生成一定數(shù)量的不重復(fù)隨機(jī)數(shù)
* $min 和 $max: 指定隨機(jī)數(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;
?>


程序運(yùn)行如下:
復(fù)制代碼 代碼如下:

2,3,4,6,7,8,9,10,11,12,13,16,20,21,22,24

補(bǔ)充幾點(diǎn)說(shuō)明:
生成隨機(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)麻煩。

相關(guān)文章

最新評(píng)論