解题思路

二维数组中的查找

http://www.nowcoder.com/questionTerminal/abc3fe2ce8e146608e868a70efebf62e

首先我们看题目从左到右对应从小到大 从上到下对应从小到大,那么我们可以判断每一行的最后一个数是否大于target 如果大于,我们则在当前行进行遍历,否则跳转到下一行,到最后都没找到则返回false

function Find($target, $array)
{
   $len = count($array);
   for($i=0;$i<$len;$i++){
       $le = count($array[$i]);
       if($target>$array[$i][$le-1]){
           continue;
       }else{
           for($j=0;$j<$le;$j++){
               if($array[$i][$j] ==$target ){
                   return true;
               }
           }
       }
   }
   return false;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-24 20:55
阿里国际 Java工程师 2.7k*16.0
程序员猪皮:没有超过3k的,不太好选。春招再看看
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-26 18:54
说等下个版本吧的发呆爱好者很贪睡:佬最后去了哪家呀
点赞 评论 收藏
分享
双非坐过牢:非佬,可以啊10.28笔试,11.06评估11.11,11.12两面,11.19oc➕offer
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务