非繰り返しの乱数を生成するいくつかの方法を書き留めて、コードにアクセスするだけです
コードをコピーします コードは次のとおりです:
定義('RANDOM_MAX', 100);
定義('COUNT', 10);
echo '最大ランダム数: '.RANDOM_MAX, ' ;結果数:'.COUNT, '
';
invoke_entry('rand1');
invoke_entry('rand2');
invoke_entry('rand3');
invoke_entry('rand4');
関数 invoke_entry($func_name) {
$time = 新しい時間();
$time->time_start();
call_user_func($func_name);
echo $func_name.' 消費時間: ', $time->time_spend();
echo '
';
}
関数 rand1() {
$numbers = 範囲 (1, RANDOM_MAX);
shuffle($numbers); //配列をランダムにシャッフルします
$result = array_slice($numbers, 1, COUNT);
$result を返します;
}
関数 rand2() {
$結果 = 配列();
while(count($result)
$result = array_unique($result); //配列内の重複した要素を削除します
}
$result を返します;
}
関数 rand3() {
$結果 = 配列();
while(count($result) < COUNT) {
$_tmp = mt_rand(1, RANDOM_MAX);
if(!in_array($_tmp, $result)) { //配列内に同じ要素が存在しない場合にのみ挿入が許可されます
$result[] = $_tmp;
}
}
$result を返します;
}
関数 rand4() {
$result = array();
while (count($result)
$result[] = mt_rand(1, RANDOM_MAX);
$result = array_flip(array_flip($result)); //array_flip は配列のキーと値を交換します
}
$result を返します;
}
授業時間{
プライベート $_start;
パブリック関数 time_start() {
$this->_start = $this->microtime_float();
}
パブリック関数 time_spend() {
$this->microtime_float() を返す - $this->_start;
}
プライベート関数 microtime_float() {
list($usec, $sec) =explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
}
4番目の方法であるflipメソッドについて説明します。array_flip()を使用して配列のキーと値を反転します。このとき、重複したキーは上書きされます。重複した値を削除するのと同じです。
いくつかの方法の効率を調べます:
配列が大きい場合、array_unique() を使用するとパフォーマンスが低下します。もちろん、shuffle() もこの影響を受けます。
http://www.bkjia.com/PHPjc/976033.html