下面來介紹兩個PHP中隨機產生一組不重復的數字實現程序代碼,有需要學習的朋友可參考參考。 代碼如下 復制代碼
<?php
/**
* PHP獲取一組隨機數字不重復
*/
$a = microtime();
function createRandID($m){
// 產生一個從1到$m的數組
$arr = range(1,$m);
// 打亂數組
shuffle ($arr);
// 取前十個
for($i=0;$i<=10;$i++){
// 賦值給新數組$n
$n[] = $arr[$i];
}
// 返回這組數字
return implode($n,',');
}
echo createRandID(700000);
echo '<br />';
echo $a - microtime();
?>
執行結果:
560875,593409,325987,658308,248054,205426,375413,676243,485853,575393,115975
0.672761
由以上結果可以看到,時間花了0.6。我們把隨機數范圍從700000調到900000再看看執行結果
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 7200000 bytes) in /data0/htdocs/www/a.php on line 10
數組太大程序跑不下了!!
代碼如下 復制代碼<?php
/**
* PHP獲取一組隨機數字不重復
* 瓊台博客
*/
$a = microtime();
function createRandID($m){
// 注意,要先聲明一個空數組,否則while裡的in_array會報錯
$arr = array();
// 使用while循環,只要不夠10個就永遠循環
while(count($arr)<=10){
// 產生一個隨機數
$a = rand(1,$m);
// 判斷:如果產生的隨機數不再數組裡就賦值到數組裡
// 主要避免產生重復的數字
if(!in_array($a,$arr)){
// 把隨機數賦值到數組裡
$arr[] = $a;
}
}
// 返回產生的隨機數字
return implode($arr,',');
}
echo createRandID(700000);
echo '<br />';
echo $a - microtime();
?>
執行結果:
308326,155128,280424,493174,214855,219990,482837,66329,512934,232527,386975
0.00015699999999996
由以上執行結果可以看到,時間根本可以忽略不計,我們把隨機數范圍從700000調到999999再看看執行結果
392281,822956,401282,176255,143076,501802,393338,546922,21836,601991,362006
0.00013600000000002
執行結果跟最大取數值設置都沒有絲毫關系,還是跑的挺快!