74. 搜索二维矩阵

题目链接:力扣

解题思路:因为矩阵整体上是有序的,所以可以先二分查找target在哪一行中,然后再次二分查找target在当前行的哪一列中。

具体算法如下:

  1. 对行使用二分查找:
    1. 初始值:
      1. int m = matrix.length
      2. int n = matrtix[0].length
      3. int rowLeft = 0;
      4. int rowRight = 0;
      5. boolean result = false:记录是否找到目标
    2. 如果rowLeft < rowRight,则循环使用二分进行查找:
      1. rowMid = (rowLeft + rowRight)/2
      2. 如果 matrix[rowMid][n-1] < target:当前行最后一个元素比target还小,令rowLeft = rowMid+1
      3. 如果 matrix[rowMid][0] > target:当前行的第一个元素比target还大,令rowRight = rowMid
      4. 否则,说明,如果target存在,则target肯定在当前这一行:
        1. 初始值:
          1. colLeft = 0
          2. colRight = n
        2. 如果colLeft < colRight,则对这一行再次循环使用二分查找:
          1. colMid = (colLeft + colRight)/2
          2. 如果matrix[rowMid][colmid] > target:则colRight = colMid
          3. 如果 matrix[rowMid][colmid] < target:则colLeft = colMid++1
          4. 否则,说明matrix[rowMid][colmid] = target:
            1. 令result = true
            2. break退出循环
        3. break退出外层循环
    3. return result;

AC代码

java 复制代码
class Solution {
    public static boolean searchMatrix(int[][] matrix, int target) {
        int m = matrix.length;
        int n = matrix[0].length;
        int rowLeft = 0;
        int rowRight = m;
        boolean result = false;
        while (rowLeft < rowRight) {
            int rowMid = (rowLeft + rowRight) / 2;
            if (matrix[rowMid][n - 1] < target) {
                rowLeft = rowMid + 1;
            } else if (matrix[rowMid][0] > target) {
                rowRight = rowMid;
            } else {
                int colLeft = 0;
                int colRight = n;
                while (colLeft < colRight) {
                    int colMid = (colLeft + colRight) / 2;
                    if (matrix[rowMid][colMid] > target) {
                        colRight = colMid;
                    } else if (matrix[rowMid][colMid] < target) {
                        colLeft = colMid + 1;
                    } else {
                        result = true;
                        break;
                    }
                }
                break;
            }
        }
        return result;
    }
}
相关推荐
明朝百晓生3 分钟前
【强化学习】【1】【PyTorch】【强化学习简介优化框架】
算法
loser~曹8 分钟前
基于快速排序解决 leetcode hot215 查找数组中第k大的数字
数据结构·算法·leetcode
Dream it possible!14 分钟前
LeetCode 热题 100_打家劫舍(83_198_中等_C++)(动态规划)
c++·算法·leetcode·动态规划
zhouziyi070119 分钟前
【蓝桥杯14天冲刺课题单】Day 8
c++·算法·蓝桥杯
SylviaW0823 分钟前
python-leetcode 62.搜索插入位置
数据结构·算法·leetcode
舔甜歌姬的EGUMI LEGACY2 小时前
【算法day28】解数独——编写一个程序,通过填充空格来解决数独问题
算法
welkin2 小时前
KMP 个人理解
前端·算法
半桔2 小时前
红黑树剖析
c语言·开发语言·数据结构·c++·后端·算法
eason_fan2 小时前
前端面试手撕代码(字节)
前端·算法·面试
今天_也很困2 小时前
牛客2025年愚人节比赛
c++·算法