php怎么找數(shù)組中的最大值 php數(shù)組原理?
php數(shù)組原理?PHP數(shù)組的底層實(shí)現(xiàn)是分散列表,也稱為hashTablPHP多維數(shù)組根據(jù)值搜索對(duì)應(yīng)的鍵,你一般用什么辦法?引言我們講解了很多種PHP數(shù)組操作的引用場(chǎng)景。今天我們接著分享這方面的知識(shí),說(shuō)
php數(shù)組原理?
PHP數(shù)組的底層實(shí)現(xiàn)是分散列表,也稱為hashTabl
PHP多維數(shù)組根據(jù)值搜索對(duì)應(yīng)的鍵,你一般用什么辦法?
引言我們講解了很多種PHP數(shù)組操作的引用場(chǎng)景。今天我們接著分享這方面的知識(shí),說(shuō)一說(shuō)對(duì)于多維數(shù)組,如何根據(jù)值搜索,并返回?cái)?shù)組的索引值。
學(xué)習(xí)時(shí)間最開(kāi)始我們習(xí)慣于跟隨本能寫(xiě)代碼,下意識(shí)地開(kāi)始用 for 循環(huán),對(duì)數(shù)組進(jìn)行遍歷,然后挨個(gè)比對(duì),如果值相等,就返回索引值,如果沒(méi)有匹配上,就是不存在。
假如原始數(shù)組是如下圖一樣的關(guān)聯(lián)數(shù)組。
程序邏輯很簡(jiǎn)單,我們使用代碼實(shí)現(xiàn)一下:
function searchForId($id, $array) { foreach ($array as $key gt $val) { if ($val[uid] $id) { return $key } } return null }
這個(gè)函數(shù)接收一個(gè)值,與數(shù)組,如果匹配上就將數(shù)組的索引返回,如果不存在則返回 null。因?yàn)榈谝粚咏Y(jié)構(gòu)沒(méi)有手動(dòng)指定索引值,所以默認(rèn)是從0開(kāi)始的數(shù)字索引。
使用起來(lái)是這樣的:
$id searchForId(100, $userdb)
執(zhí)行結(jié)束后,輸出應(yīng)該為0。
當(dāng)然了,上面寫(xiě)的函數(shù)具有通用性,對(duì)于特殊的案例,我們應(yīng)該隨機(jī)應(yīng)變。對(duì)于上述 $userdb 關(guān)聯(lián)數(shù)組的結(jié)構(gòu),顯然,使用PHP內(nèi)置的函數(shù)操作起來(lái),更為直觀和快捷。
我們只需要先把 uid 列的元素全部取出,因?yàn)樯蠈咏Y(jié)構(gòu)是默認(rèn)數(shù)字索引,所以此處不用手動(dòng)指定索引值;然后,在提取的數(shù)組中搜索值,使用 array_search 執(zhí)行返回鍵。
總結(jié)為代碼,就一行:
$key array_search(100, array_column($userdb, uid))
執(zhí)行結(jié)果跟上面的 searchForId 函數(shù)一致。
深入討論上面的函數(shù)和第二個(gè)解決方有問(wèn)題,就是僅僅返回了第一個(gè)匹配的鍵。像下面這樣寫(xiě),肯定問(wèn)題不大:
$key array_search(40489, array_column($userdb, uid))
但是如果在數(shù)組中有重復(fù)的值,而 uid 列也不唯一,要把所有的匹配結(jié)果都返回,該怎么做呢?不會(huì)又要修改 searchForId 函數(shù),重新倒騰?
其實(shí)大可不必,PHP提供了這樣的功能,只需改用 array_keys 函數(shù)即可:
$keys array_keys(array_column($userdb, uid), 40489)
你肯定經(jīng)常使用 array_keys 函數(shù)用于返回整個(gè)數(shù)組的鍵,但是它的第二個(gè)參數(shù),恰恰是在指定時(shí),擁有可搜索的功能。這確實(shí)有些冷門(mén)。
再進(jìn)一步。
上面返回的是數(shù)組對(duì)應(yīng)的鍵,那如果想要鍵和值一并關(guān)聯(lián)返回,一行代碼能搞定嗎?可以的,修改一下就行了,使用 array_combine 函數(shù)將鍵和值組裝起來(lái)返回:
$keys array_keys(array_combine(array_keys($userdb), array_column($userdb, uid)),40489)
寫(xiě)在最后本文通過(guò)特定的數(shù)組搜索需求,延伸到手動(dòng)造輪子,把特殊的特性推向一般,并使用PHP內(nèi)置的數(shù)組處理函數(shù),進(jìn)行功能裁切,簡(jiǎn)潔而高效。善用數(shù)組函數(shù)是硬功夫。
Happy coding :_)
我是 @程序員小助手 ,持續(xù)分享編程知識(shí),歡迎關(guān)注。