php利用array_search與array_column實(shí)現(xiàn)二維數(shù)組查找
在看php手冊(cè)數(shù)組函數(shù)時(shí),看到了一個(gè)高贊的用戶回答傳送門,利用array_search與array_column實(shí)現(xiàn)二維數(shù)組查找,不用自己寫個(gè)循環(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很大,建議使用一個(gè)變量,避免搜索每個(gè)元素時(shí)都調(diào)用array_column() $uid = array_column($userdb, 'uid'); $found_key = array_search(40489, $uid); */ var_dump($found_key); ?>
題目描述:
在一個(gè)二維數(shù)組中,每一行都按照從左到右遞增的順序排序,每一列都按照從上到下遞增的順序排序。請(qǐng)完成一個(gè)函數(shù),輸入這樣的一個(gè)二維數(shù)組和一個(gè)整數(shù),判斷數(shù)組中是否含有該整數(shù)。
代碼:
<?php function findInOneArray($target, $array){ if(array_search($target,$array)!==false) return true; //1、array_search()是在以為數(shù)組中來找,現(xiàn)在我們要在二維數(shù)組數(shù)組中來,肯定要借用這個(gè) else return false; //2、!==false的真正用法,是既有返回false,又有返回表示false數(shù)組的0的時(shí)候 } function Find($target, $array) { foreach($array as $key => $val){ if(findInOneArray($target, $val)) return true; } return false; }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Laravel ORM 數(shù)據(jù)model操作教程
今天小編就為大家分享一篇Laravel ORM 數(shù)據(jù)model操作教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10PHP依賴倒置(Dependency Injection)代碼實(shí)例
這篇文章主要介紹了PHP依賴倒置(Dependency Injection)代碼實(shí)例本文只提供實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-10-10TP5(thinkPHP框架)實(shí)現(xiàn)后臺(tái)清除緩存功能示例
這篇文章主要介紹了TP5(thinkPHP框架)實(shí)現(xiàn)后臺(tái)清除緩存功能,結(jié)合實(shí)例形式分析了thinkPHP5結(jié)合layui插件實(shí)現(xiàn)后臺(tái)緩存清除相關(guān)的文件遍歷、刪除等操作技巧,需要的朋友可以參考下2019-05-05Laravel框架實(shí)現(xiàn)的批量刪除功能示例
這篇文章主要介紹了Laravel框架實(shí)現(xiàn)的批量刪除功能,結(jié)合實(shí)例形式分析了Laravel框架批量刪除功能相關(guān)的前端界面布局及后臺(tái)控制器實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-01-01thinkphp ajaxfileupload實(shí)現(xiàn)異步上傳圖片的示例
本篇文章主要介紹了thinkphp ajaxfileupload實(shí)現(xiàn)異步上傳圖片的示例,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08