搜索二维矩阵 II

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:

  • 每行的元素从左到右升序排列。
  • 每列的元素从上到下升序排列。

示例 1:

输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 5
输出:true

示例 2:

输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 20
输出:false

 

var searchMatrix = function(matrix, target) {
        // 检查矩阵是否为空或不合法
        if (!matrix || matrix.length === 0 || matrix[0].length === 0) {
            return false;
        }
        let countY = matrix.length;
        let countX = matrix[0].length;
        let row = countY - 1;
        let col = 0;
        while (row >= 0 && col < countX) {
            if (matrix[row][col] === target) {
                return true;
            } else if (matrix[row][col] < target) {
                col++;
            } else {
                row--;
            }
        }
        return false;
    };

 

posted @ 2024-12-02 17:22  小杨同学906  阅读(1)  评论(0编辑  收藏  举报