一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - PHP教程 - php 數(shù)組元素快速去重

php 數(shù)組元素快速去重

2021-05-16 22:41傲雪星楓 PHP教程

本篇文章主要介紹了php數(shù)組元素快速去重的方法,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧

1.使用array_unique方法進(jìn)行去重

對(duì)數(shù)組元素進(jìn)行去重,我們一般會(huì)使用array_unique方法,使用這個(gè)方法可以把數(shù)組中的元素去重。

?
1
2
3
4
5
6
<?php
$arr = array(1,1,2,3,3,3,4,4,5,6,6,7,8,8,9,9,9);
$arr = array_unique($arr);
$arr = array_values($arr);
print_r($arr);
?>

輸出:

?
1
2
3
4
5
6
7
8
9
10
11
12
Array
(
  [0] => 1
  [1] => 2
  [2] => 3
  [3] => 4
  [4] => 5
  [5] => 6
  [6] => 7
  [7] => 8
  [8] => 9
)

去重后,鍵值會(huì)不按順序,可以使用array_values把鍵值重新排序。

2.使用array_unique方法去重效率

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
<?php
$arr = array();
 
// 創(chuàng)建100000個(gè)隨機(jī)元素的數(shù)組
for($i=0; $i<100000; $i++){
  $arr[] = mt_rand(1,99);
}
 
// 記錄開(kāi)始時(shí)間
$starttime = getMicrotime();
 
// 去重
$arr = array_unique($arr);
 
// 記錄結(jié)束時(shí)間
$endtime = getMicrotime();
 
$arr = array_values($arr);
 
echo 'unique count:'.count($arr).'<br>';
echo 'run time:'.(float)(($endtime-$starttime)*1000).'ms<br>';
echo 'use memory:'.getUseMemory();
 
/**
 * 獲取使用內(nèi)存
 * @return float
 */
function getUseMemory(){
  $use_memory = round(memory_get_usage(true)/1024,2).'kb';
  return $use_memory;
}
/**
 * 獲取microtime
 * @return float
 */
function getMicrotime(){
  list($usec, $sec) = explode(' ', microtime());
  return (float)$usec + (float)$sec;
}
?>

unique count:99
run time:653.39303016663ms
use memory:5120kb

使用array_unique方法去重,運(yùn)行時(shí)間需要約650ms,內(nèi)存占用約5m

3.更快的數(shù)組去重方法

PHP有一個(gè)鍵值互換的方法array_flip,我們可以使用這個(gè)方法去重,因?yàn)殒I值互換,原來(lái)重復(fù)的值會(huì)變?yōu)橄嗤逆I。

然后再進(jìn)行一次鍵值互換,把鍵和值換回來(lái)則可以完成去重。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<?php
$arr = array();
 
// 創(chuàng)建100000個(gè)隨機(jī)元素的數(shù)組
for($i=0; $i<100000; $i++){
  $arr[] = mt_rand(1,99);
}
 
// 記錄開(kāi)始時(shí)間
$starttime = getMicrotime();
 
// 使用鍵值互換去重
$arr = array_flip($arr);
$arr = array_flip($arr);
 
// 記錄結(jié)束時(shí)間
$endtime = getMicrotime();
 
$arr = array_values($arr);
 
echo 'unique count:'.count($arr).'<br>';
echo 'run time:'.(float)(($endtime-$starttime)*1000).'ms<br>';
echo 'use memory:'.getUseMemory();
 
/**
 * 獲取使用內(nèi)存
 * @return float
 */
function getUseMemory(){
  $use_memory = round(memory_get_usage(true)/1024,2).'kb';
  return $use_memory;
}
/**
 * 獲取microtime
 * @return float
 */
function getMicrotime(){
  list($usec, $sec) = explode(' ', microtime());
  return (float)$usec + (float)$sec;
}
?>

unique count:99
run time:12.840032577515ms
use memory:768kb

使用array_flip方法去重,運(yùn)行時(shí)間需要約18ms,內(nèi)存占用約2m

因此使用array_flip方法去重比使用array_unique方法運(yùn)行時(shí)間減少98%,內(nèi)存占用減少4/5;

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持服務(wù)器之家!

原文鏈接:http://blog.csdn.net/fdipzone/article/details/50573353

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 四虎永久网址影院 | 天堂樱桃bt在线www | 成人性生交小说免费看 | 久久亚洲免费视频 | 师尊被各种play打屁股 | 欧美一卡2卡三卡4卡5卡免费观看 | 草莓香蕉绿巨人丝瓜榴莲18 | 亚洲国产精品嫩草影院久久 | 国产精品亚洲精品观看不卡 | 色先锋影音资源 | 久久成人国产精品一区二区 | 男生操女生漫画 | 好大夫在线个人空间 | 把美女屁股眼扒开图片 | 手机在线免费观看视频 | 岛国最新资源网站 | 国产高清不卡视频在线播放 | 青草草在线 | 成人永久免费 | 精品成人一区二区 | 国产日韩欧美成人 | 掰开逼操 | 国产成人亚洲综合91精品555 | 亚洲大片免费观看 | 亚洲精品国产一区二区三区在 | 欧美人与日本人xx在线视频 | 青草社区视频 | 日本性爱 | 风间由美一区二区av101 | 天天爱天天做天天爽天天躁 | 香蕉91xj.cc| 闺蜜的样子小说安沁在线阅读 | 亚洲高清国产拍精品动图 | 白丝捆绑调教 | 亚洲日韩中文字幕一区 | www.91在线播放 | 87影院在线观看视频在线观看 | 99久久一区二区精品 | 国产一区二区三区四区波多野结衣 | 免费网站看v片在线香蕉 | 欧美激情影音先锋 |