站長(zhǎng)資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

php怎么實(shí)現(xiàn)數(shù)組隨機(jī)且不重復(fù)

php實(shí)現(xiàn)數(shù)組隨機(jī)且不重復(fù)的方法:首先創(chuàng)建一個(gè)PHP示例文件;然后利用“array_flip()”函數(shù)將數(shù)組的鍵和值翻轉(zhuǎn);接著利用php數(shù)組特性,覆蓋重復(fù)的鍵并再翻轉(zhuǎn)一次;最后去掉重復(fù)的值即可。

php怎么實(shí)現(xiàn)數(shù)組隨機(jī)且不重復(fù)

推薦:《PHP視頻教程》

下面寫(xiě)幾種生成不重復(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); 	} }   ?>

說(shuō)一下第四種方法,就是翻翻法了,利用array_flip()將數(shù)組的鍵和值翻轉(zhuǎn),利用php數(shù)組特性,重復(fù)的鍵會(huì)覆蓋,此時(shí)再翻轉(zhuǎn)一次,就相同于去掉了重復(fù)的值。

以上幾種方法只是簡(jiǎn)單的例子,有的方法適用范圍有限。

在看看幾種方法的效率:

php怎么實(shí)現(xiàn)數(shù)組隨機(jī)且不重復(fù)

php怎么實(shí)現(xiàn)數(shù)組隨機(jī)且不重復(fù)

用array_unique()在數(shù)組較大時(shí)性能比較差,當(dāng)然shuffle()也會(huì)受此影響。

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)
四虎必出精品亚洲高清| 人妻少妇乱子伦精品| 亚洲精品福利网泷泽萝拉| 亚洲日韩AV一区二区三区四区| 亚洲国产精品不卡在线电影| 日韩专区在线观看| 精品久久中文字幕| 久久国产乱子伦精品免费看| 中文字幕无码日韩专区免费| 免费精品无码AV片在线观看| 国产一区二区精品尤物| 国产精品美女久久久浪潮av| 无码精品一区二区三区在线| 中文字幕精品无码久久久久久3D日动漫 | 亚洲精品午夜久久久伊人| 久久精品亚洲视频| 精品一区二区三区影院在线午夜| 精品国产乱码久久久久久人妻 | 无码精品人妻一区二区三区免费| .精品久久久麻豆国产精品| 精品无码人妻一区二区三区| 国产精品成人观看视频| 国产在线拍揄自揄视精品| 久久精品成人免费网站| 2021免费日韩视频网| 国产亚洲精品国产福利在线观看 | 久久精品免费电影| 国产AV无码专区亚洲精品| 完整观看高清秒播国内外精品资源| 亚洲国产日韩在线观频| jizz国产精品jizz中国| 91大神精品在线观看| 中文字幕精品无码亚洲字| 国产精品激情综合久久| 亚洲综合精品网站| 欧美日韩精品不卡在线观看| 亚洲精品视频在线| 久久久精品2019中文字幕之3| 久久精品国产999大香线焦| 久re这里只有精品最新地址| 无码人妻精品一区二区在线视频|