【剑指offer】二维数组中的查找

二维数组中的查找

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

题目描述
在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
思路与代码
暴力二维循环是解法之一,但考虑题目给定的排序特性,越右边的越大,越上面的越小,可以减少循环次数,代码如下。

public class Solution {
public boolean Find(int target, int [][] array) {
boolean found = false;
int rows = array.length;
int cols = array[0].length;
int col = cols - 1;
int row = 0;
while(row = 0) {
if(target > array[row][col]) row++;
else if(target < array[row][col]) col--;
else {
found = true;
break;
}
}
return found;
}
}
全部评论

相关推荐

评论
点赞
收藏
分享
牛客网
牛客企业服务