**PHP乱数アルゴリズム

1893 ワード


出力:
Array( [0] => 6 [1] => 8 [2] => 13 [3] => 16 [4] => 17 [5] => 20 [6] => 21 [7] => 22 [8] => 28 [9] => 29)
 
-----------------------------------------
参照先:
WebアプリケーションでもWAPでもモバイルアプリケーションでも,乱数にはその活躍の場がある.最近接触したいくつかの小さな項目の中で、私もよく乱数やランダム配列と付き合う必要があるので、PHPがどのように重複しない乱数を生成するかについてよく使われるいくつかの方法をまとめます.
方法1:
 
 
   
<?php 
$numbers = range (1,50); 
//shuffle  
shuffle ($numbers); 
//array_slice  
$num=6; 
$result = array_slice($numbers,0,$num); 
print_r($result); 
?>

 
方法2:
 
 
   
<?php 
$numbers = range (1,20); 
// , ,
srand ((float)microtime()*1000000); 
shuffle ($numbers); 
// list ( )
while (list(, $number) = each ($numbers)) { 
echo "$number "; 

?>

 
方法3:
 
 
   
<?php 
function NoRand($begin=0,$end=20,$limit=5){ 
$rand_array=range($begin,$end); 
shuffle($rand_array);//  
return array_slice($rand_array,0,$limit);// $limit  

print_r(NoRand()); 
?>

 
上記では、1~20の間に5つの重複しない値をランダムに生成することができる
方法4:
 
 
   
<?php 
$tmp=array(); 
while(count($tmp)<5){ 
$tmp[]=mt_rand(1,20); 
$tmp=array_unique($tmp); 

print_r($tmp);
?>

 
方法5:
 
 
   
<?php 
$tmp = range(1,30);
print_r(array_rand($tmp,10));
?>