php實(shí)現(xiàn)數(shù)組隨機(jī)且不重復(fù)的方法:首先創(chuàng)建一個(gè)PHP示例文件;然后利用“array_flip()”函數(shù)將數(shù)組的鍵和值翻轉(zhuǎn);接著利用php數(shù)組特性,覆蓋重復(fù)的鍵并再翻轉(zhuǎn)一次;最后去掉重復(fù)的值即可。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名申請(qǐng)、網(wǎng)頁(yè)空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、市北網(wǎng)站維護(hù)、網(wǎng)站推廣。
推薦:《PHP視頻教程》
下面寫幾種生成不重復(fù)隨機(jī)數(shù)的方法,直接上代碼吧
<?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); //隨機(jī)打亂數(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()更好更快的隨機(jī)函數(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ù)組中不存在相同的元素時(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ù)的鍵會(huì)覆蓋,此時(shí)再翻轉(zhuǎn)一次,就相同于去掉了重復(fù)的值。
以上幾種方法只是簡(jiǎn)單的例子,有的方法適用范圍有限。
在看看幾種方法的效率:
用array_unique()在數(shù)組較大時(shí)性能比較差,當(dāng)然shuffle()也會(huì)受此影響。
當(dāng)前名稱:php怎么實(shí)現(xiàn)數(shù)組隨機(jī)且不重復(fù)
網(wǎng)頁(yè)鏈接:http://m.rwnh.cn/article38/cgedsp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、域名注冊(cè)、網(wǎng)站內(nèi)鏈、網(wǎng)站營(yíng)銷、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容