【剑指offer】 二维数组中的查找
题目
在一个 n * m 的二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个高效的函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/er-wei-shu-zu-zhong-de-cha-zhao-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
我的答案
/**
* @param {number[][]} matrix
* @param {number} target
* @return {boolean}
*/
var findNumberIn2DArray = function (matrix, target) {
if(matrix.length===0){
return false;
}
var i = 0;
var j = matrix[0].length - 1;
while (matrix[i][j] !== target) {
if (matrix[i][j] > target) {
j--;
} else if (matrix[i][j] < target) {
i++;
}
if(i>=matrix.length || j<0){
return false;
}
}
return true;
};
如果按照顺着题目的思维,这道题会变得非常麻烦。想要快速找到,就需要尽可能找到比较简单的寻找路径。与元素比较大小的结果只会导向一个方向。我们注意到,从二维数组的右上角(或左下角)开始,比较大小后只有向左向下(或向上向右)。如果超出数据的界限了,就说明没有。
标题:【剑指offer】 二维数组中的查找
作者:limanting
地址:https://blog.manxiaozhi.com/articles/2021/08/26/1629987392204.html