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;
    }
}
相关推荐
卷福同学21 分钟前
【AI编程】AI+高德MCP不到10分钟搞定上海三日游
人工智能·算法·程序员
mit6.82423 分钟前
[Leetcode] 预处理 | 多叉树bfs | 格雷编码 | static_cast | 矩阵对角线
算法
The_Killer.35 分钟前
格密码--数学基础--06对偶空间与对偶格
学习·线性代数·密码学
皮卡蛋炒饭.1 小时前
数据结构—排序
数据结构·算法·排序算法
??tobenewyorker2 小时前
力扣打卡第23天 二叉搜索树中的众数
数据结构·算法·leetcode
贝塔西塔2 小时前
一文读懂动态规划:多种经典问题和思路
算法·leetcode·动态规划
众链网络2 小时前
AI进化论08:机器学习的崛起——数据和算法的“二人转”,AI“闷声发大财”
人工智能·算法·机器学习
3 小时前
Unity开发中常用的洗牌算法
java·算法·unity·游戏引擎·游戏开发
飒飒真编程4 小时前
C++类模板继承部分知识及测试代码
开发语言·c++·算法
GeminiGlory4 小时前
算法练习6-大数乘法(高精度乘法)
算法