**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));
?>