在看php手冊數組函數時,看到了一個高贊的用戶回答傳送門,利用array_search與array_column實現二維數組查找,不用自己寫個循環,減少工作量。
<?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很大,建議使用一個變量,避免搜索每個元素時都調用array_column() $uid = array_column($userdb, 'uid'); $found_key = array_search(40489, $uid); */var_dump($found_key); ?>
題目描述:
在一個二維數組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請完成一個函數,輸入這樣的一個二維數組和一個整數,判斷數組中是否含有該整數。
代碼:
<?phpfunction findInOneArray($target, $array){ if(array_search($target,$array)!==false) return true; //1、array_search()是在以為數組中來找,現在我們要在二維數組數組中來,肯定要借用這個 else return false; //2、!==false的真正用法,是既有返回false,又有返回表示false數組的0的時候}function Find($target, $array){ foreach($array as $key => $val){ if(findInOneArray($target, $val)) return true; } return false;}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答
圖片精選