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;
    }
}
相关推荐
spcier38 分钟前
图论拓扑排序-Kahn 算法
算法·图论
知星小度S39 分钟前
动态规划(一)——思想入门
算法·动态规划
攻城狮凌霄41 分钟前
PHP接单涨薪系列(七十一):如何用Neo4j构建借贷关系图谱?解析资金流水时空矩阵揪出“砍头息“和“循环贷“
矩阵·php·neo4j
ysa05103041 分钟前
动态规划-逆向
c++·笔记·算法
燃于AC之乐44 分钟前
我的算法修炼之路--7—— 手撕多重背包、贪心+差分,DFS,从数学建模到路径DP
c++·算法·数学建模·深度优先·动态规划(多重背包)·贪心 + 差分
chinesegf1 小时前
文本嵌入模型的比较(一)
人工智能·算法·机器学习
We་ct2 小时前
LeetCode 6. Z 字形变换:两种解法深度解析与优化
前端·算法·leetcode·typescript
REDcker2 小时前
Redis容灾策略与哈希槽算法详解
redis·算法·哈希算法
福楠2 小时前
C++ STL | map、multimap
c语言·开发语言·数据结构·c++·算法
Sarvartha3 小时前
二分查找学习笔记
数据结构·c++·算法