【剑指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; } }