PHP數(shù)組去重的更快實(shí)現(xiàn)方式分析
本文實(shí)例講述了PHP數(shù)組去重的更快實(shí)現(xiàn)方式。分享給大家供大家參考,具體如下:
概述
使用PHP的array_unique()
函數(shù)允許你傳遞一個數(shù)組,然后移除重復(fù)的值,返回一個擁有唯一值的數(shù)組。這個函數(shù)大多數(shù)情況下都能工作得很好。但是,如果你嘗試在一個大的數(shù)組里使用array_unique()
函數(shù),它會運(yùn)行地慢一些。
有一個比較好而且更快的函數(shù)array_flip()
來替代使用array_unique()
函數(shù)來創(chuàng)建唯一的數(shù)組。這個魔法般的函數(shù)會交換數(shù)組里面每一個元素的鍵和值,因?yàn)殒I值必須唯一,因此,你會得到跟array_unique()
函數(shù)一樣的結(jié)果。
PHP代碼:
/* 創(chuàng)建一個包含重復(fù)值的,一共四個元素的數(shù)組 */ $array = array('green','blue','orange','blue'); /* 翻轉(zhuǎn)數(shù)組,你將會得到唯一鍵值的數(shù)組 array('green'=>0,'blue'=>1,'orange'=>2); */ $array = array_flip($array); /* 然后再翻轉(zhuǎn)一次,將鍵和值重新放置,然后得到數(shù)組:array(0=>'green',1=>'blue',2=>'orange'); */ $array = array_flip($array); print_r($array)
運(yùn)行結(jié)果:
Array ( [0] => green [3] => blue [2] => orange )
因?yàn)槲覀円呀?jīng)移除了一些元素,因此數(shù)組看起來不是正常的序列。比如我們可能會得到:array(0=>'A',2=>'B',5=>'C');
。在某些情況下,這不是一個問題,但是如果你需要數(shù)組的鍵值保持?jǐn)?shù)字的序列,你可以使用一到兩種方法解決鍵值亂序的問題。
使用array_merge修復(fù)數(shù)組的keys
添加array_flip
之后的函數(shù),將會對數(shù)組的鍵值排序并且讓它們恢復(fù)到正常的序列,如:0,1,2,3…
PHP代碼:
$array = array('green','blue','orange','blue'); $array = array_flip($array); $array = array_flip($array); /* 使用array_merge()函數(shù)修復(fù)鍵值*/ $array = array_merge($array); print_r($array)
運(yùn)行結(jié)果同上
第二種方式,使用array_keys
注意,這種修復(fù)數(shù)組鍵值的方法比使用array_merge()
函數(shù)稍微快了一點(diǎn)。你也可以在最后一步結(jié)合使用array_keys()
函數(shù)(此函數(shù)返回翻轉(zhuǎn)后的值)。然后當(dāng)你翻轉(zhuǎn)數(shù)組的值,鍵值就會根據(jù)順序創(chuàng)建。
PHP代碼:
$array = array('green','blue','orange','blue'); $array = array_flip($array); /* 跟第一個例子一樣,但是現(xiàn)在我們先提取數(shù)組的鍵值 */ $array = array_keys($array); print_r($array)
運(yùn)行結(jié)果同上
結(jié)論
非常簡單,比起在大數(shù)組使用array_unique
函數(shù),有了一個有效的性能提升。
PS:本站還有兩款比較簡單實(shí)用的在線文本去重復(fù)工具,推薦給大家使用:
在線去除重復(fù)項(xiàng)工具:
http://tools.jb51.net/code/quchong
在線文本去重復(fù)工具:
http://tools.jb51.net/aideddesign/txt_quchong
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《php常用函數(shù)與技巧總結(jié)》、《PHP錯誤與異常處理方法總結(jié)》、《PHP基本語法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》
希望本文所述對大家PHP程序設(shè)計有所幫助。
- PHP中array_keys和array_unique函數(shù)源碼的分析
- php數(shù)組函數(shù)序列之a(chǎn)rray_unique() - 去除數(shù)組中重復(fù)的元素值
- php array_unique之后json_encode需要注意
- php下判斷數(shù)組中是否存在相同的值array_unique
- PHP編程快速實(shí)現(xiàn)數(shù)組去重的方法詳解
- php 數(shù)組元素快速去重
- PHP二維數(shù)組去重算法
- php二維數(shù)組合并及去重復(fù)的方法
- PHP基于array_unique實(shí)現(xiàn)二維數(shù)組去重
相關(guān)文章
PHP保存Base64圖片base64_decode的問題整理
在本篇文章里小編給大家整理的是關(guān)于PHP保存Base64圖片base64_decode的問題,需要的朋友們參考下。2019-11-11PHP無限極分類函數(shù)的實(shí)現(xiàn)方法詳解
這篇文章主要介紹了PHP無限極分類函數(shù)的實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了php實(shí)現(xiàn)無限極分類的具體思路、實(shí)現(xiàn)代碼與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-04-04解決File size limit exceeded 錯誤的方法
本篇文章是對File size limit exceeded 錯誤進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06php自定義函數(shù)實(shí)現(xiàn)二維數(shù)組按指定key排序的方法
這篇文章主要介紹了php自定義函數(shù)實(shí)現(xiàn)二維數(shù)組按指定key排序的方法,通過自定義函數(shù)實(shí)現(xiàn)二維數(shù)組按照指定鍵值進(jìn)行排序的功能,涉及數(shù)組的遍歷與判定相關(guān)操作技巧,需要的朋友可以參考下2016-09-09PHP動態(tài)規(guī)劃解決0-1背包問題實(shí)例分析
這篇文章主要介紹了PHP動態(tài)規(guī)劃解決0-1背包問題,實(shí)例分析了背包問題的原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-03-03php實(shí)現(xiàn)的錯誤處理封裝類實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)的錯誤處理封裝類,結(jié)合具體實(shí)例形式分析了php錯誤判斷、提示及日志相關(guān)操作技巧,需要的朋友可以參考下2017-06-06