在看php手冊數(shù)組函數(shù)時,看到了一個高贊的用戶回答傳送門,利用array_search與array_column實現(xiàn)二維數(shù)組查找,不用自己寫個循環(huán),減少工作量。
?php
$userdb = array(
0 => array(
'uid' => 100,
'name' => 'Sandra Shush',
'url' => 'urlof100'
),
1 => array(
'uid' => 5465,
'name' => 'Stefanie Mcmohn',
'pic_square' => 'urlof100'
),
2 => Array(
'uid' => 40489,
'name' => 'Michael',
'pic_square' => 'urlof40489'
)
);
$found_key = array_search(40489, array_column($userdb, 'uid'));
/**
如果$userdb很大,建議使用一個變量,避免搜索每個元素時都調(diào)用array_column()
$uid = array_column($userdb, 'uid');
$found_key = array_search(40489, $uid);
*/
var_dump($found_key);
?>
在一個二維數(shù)組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請完成一個函數(shù),輸入這樣的一個二維數(shù)組和一個整數(shù),判斷數(shù)組中是否含有該整數(shù)。
?php
function findInOneArray($target, $array){
if(array_search($target,$array)!==false) return true; //1、array_search()是在以為數(shù)組中來找,現(xiàn)在我們要在二維數(shù)組數(shù)組中來,肯定要借用這個
else return false; //2、!==false的真正用法,是既有返回false,又有返回表示false數(shù)組的0的時候
}
function Find($target, $array)
{
foreach($array as $key => $val){
if(findInOneArray($target, $val)) return true;
}
return false;
}