题目描述
在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
思路
这个二维数组,从上到下,从左到右递增,也就是说,每个位置上的数都满足:左边,上边比它小,右边下边比它大,这样的话我们就可以从左下角开始,将左下角数字与目标数字做比较,如果比目标数字大,向上走,反之,向下走。
代码
function Find(target, array)
{
// write code here
let m=array.length,n=array[0].length;
let row=m-1,col=0;
if(m===0&&n===0){
return false;
}
while(row>=0&&col<=n-1){
if(array[row][col]>target){
row--
}else if(array[row][col]<target){
col++
}else return true
}
return false
}