您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)怎么在php中生成一個不重復(fù)隨機的數(shù)組,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
代碼如下:
<?php
define('RANDOM_MAX', 100);
define('COUNT', 10);
echo 'max random num: '.RANDOM_MAX, ' ;result count:'.COUNT, '<br/>';
invoke_entry('rand1');
invoke_entry('rand2');
invoke_entry('rand3');
invoke_entry('rand4');
function invoke_entry($func_name) {
$time = new time();
$time->time_start();
call_user_func($func_name);
echo $func_name.' time spend: ', $time->time_spend();
echo '<br/>';
}
function rand1() {
$numbers = range (1, RANDOM_MAX);
shuffle($numbers); //隨機打亂數(shù)組
$result = array_slice($numbers, 1, COUNT);
return $result;
}
function rand2() {
$result = array();
while(count($result)< COUNT) {
$result[] = mt_rand(1, RANDOM_MAX); //mt_rand()是比rand()更好更快的隨機函數(shù)
$result = array_unique($result); //刪除數(shù)組中重復(fù)的元素
}
return $result;
}
function rand3() {
$result = array();
while(count($result) < COUNT) {
$_tmp = mt_rand(1, RANDOM_MAX);
if(!in_array($_tmp, $result)) { //當(dāng)數(shù)組中不存在相同的元素時,才允許插入
$result[] = $_tmp;
}
}
return $result;
}
function rand4() {
$result = array();
while (count($result) < COUNT) {
$result[] = mt_rand(1, RANDOM_MAX);
$result = array_flip(array_flip($result)); //array_flip將數(shù)組的key和value交換
}
return $result;
}
class time {
private $_start;
public function time_start() {
$this->_start = $this->microtime_float();
}
public function time_spend() {
return $this->microtime_float() - $this->_start;
}
private function microtime_float() {
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
}
?>
說一下第四種方法,就是翻翻法了,利用array_flip()將數(shù)組的鍵和值翻轉(zhuǎn),利用php數(shù)組特性,重復(fù)的鍵會覆蓋,此時再翻轉(zhuǎn)一次,就相同于去掉了重復(fù)的值。
以上幾種方法只是簡單的例子,有的方法適用范圍有限。
在看看幾種方法的效率:
看完上述內(nèi)容,你們對怎么在php中生成一個不重復(fù)隨機的數(shù)組有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。