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;
    }
}
相关推荐
liujing102329291 小时前
Day09_刷题niuke20250609
java·c++·算法
不7夜宵1 小时前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
蒟蒻小袁2 小时前
力扣面试150题--课程表
算法·leetcode·面试
闻缺陷则喜何志丹2 小时前
【动态规划】B4336 [中山市赛 2023] 永别|普及+
c++·算法·动态规划·洛谷
不二狗3 小时前
每日算法 -【Swift 算法】电话号码字母组合
开发语言·算法·swift
AL流云。3 小时前
【优选算法】分治
数据结构·算法·leetcode·排序算法
C++ 老炮儿的技术栈9 小时前
UDP 与 TCP 的区别是什么?
开发语言·c++·windows·算法·visual studio
殇者知忧9 小时前
【论文笔记】若干矿井粉尘检测算法概述
深度学习·神经网络·算法·随机森林·机器学习·支持向量机·计算机视觉
mochensage11 小时前
C++信息学竞赛中常用函数的一般用法
java·c++·算法
chengooooooo11 小时前
leetcode Top100 238. 除自身以外数组的乘积|数组系列
算法·leetcode