算法-搜索二维矩阵 II

1、题目来源

240. 搜索二维矩阵 II - 力扣(LeetCode)

2、题目描述

编写一个高效的算法来搜索 m xn 矩阵 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

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= n, m <= 300
  • -109 <= matrix[i][j] <= 109
  • 每行的所有元素从左到右升序排列
  • 每列的所有元素从上到下升序排列
  • -109 <= target <= 109

3、题解分享

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        // 思路:直接遍历
        for (int[] row : matrix) {
            for (int element : row) {
                if (element == target) {
                    return true;
                }
            }
        }
        return false;
    }
}
java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        //思路:二分查找 + 每行进行二分搜索
        for (int[] row : matrix) {
            int index = search(row, target);
            if (index >= 0) {
                return true;
            }
        }
        return false;
    }

    public int search(int[] nums, int target) {
        int low = 0, high = nums.length - 1;
        while (low <= high) {
            int mid = (high - low) / 2 + low;
            int num = nums[mid];
            if (num == target) {
                return mid;
            } else if (num > target) {
                high = mid - 1;
            } else {
                low = mid + 1;
            }
        }
        return -1;
    }
}
java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        // 思路:直接搜索 + 从左下角或者右上角 往对角线方向搜索
        int n = matrix.length;
        int m = matrix[0].length;
        int row = n -1,col = 0;
        while(row >=0 && col < m){
            if(matrix[row][col] == target){
                return true;
            }else if(matrix[row][col] > target){
                --row;
            }else{
                ++col;
            }
        }
        return false;
    }
}
相关推荐
小刘鸭地下城7 分钟前
深入浅出链表:从基础概念到核心操作全面解析
算法
小刘鸭地下城17 分钟前
哈希表核心精要:从 O(1) 原理到链式地址与开放寻址
算法
BenChuat41 分钟前
Java常见排序算法实现
java·算法·排序算法
元亓亓亓1 小时前
LeetCode热题100--105. 从前序与中序遍历序列构造二叉树--中等
算法·leetcode·职场和发展
纪元A梦1 小时前
贪心算法在SDN流表优化中的应用
算法·贪心算法
JCBP_2 小时前
QT(4)
开发语言·汇编·c++·qt·算法
码熔burning2 小时前
JVM 垃圾收集算法详解!
jvm·算法
淘小白_TXB21962 小时前
头条号矩阵运营经验访谈记录
线性代数·矩阵
小柴狗2 小时前
C语言关键字详解:static、const、volatile
算法
仙俊红4 小时前
LeetCode每日一题,20250914
算法·leetcode·职场和发展