题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序,请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
思路:从第一行的最后一个数开始比较,如果该数比较大,则行数加一,如果该数较小,则列数减一。
public class Main1 {
public static boolean hasTheNumber(int[][] number,int target){
int rows = number.length;
int cols = number[0].length;
int row = 0;
int col = cols-1;
while(row>=0 &&rows>row && cols>col && col>=0){
if(number[row][col]==target){
return true;
}else if (number[row][col]>target){
col--;
}else{
row++;
}
}
return false;
}
}