二维数组的查找
题目描述
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
输入描述:
array: 待查找的二维数组 target:查找的数字
输出描述:
查找到返回true,查找不到返回false
代码:
public class Solution {
public static boolean Find(int [][] array,int target) {
//出错处理
if(array == null){return false;}
int row = array.length;
int col = array[0].length;
int i = 0, j = col-1;
//从array[0][col-1]开始比较,若比它小表示在其左侧列j-1,若比它大表示在其下行i+1
while(i <= row-1 && j >= 0){
int t = array[i][j];
if(target < t){
j--;
}else if(target > t){
i++;
}else{
return true;
}
}
return false;
}
}