力扣74. 搜索二维矩阵(二分查找)

Problem: 74. 搜索二维矩阵

文章目录

题目描述

思路

思路1:映射为一维数组二分查找

1.由于题目矩阵中的元素整体是升序的,我们可以将其放置在一个大小为 m × n m \times n m×n的一维数组array中进行二分查找

2.对应的映射关系是arraymid == marmid / nmid % n

思路2:直接在二维矩阵上进行二分查找

1.先对二维矩阵的第一列进行二分查找,找到小于等于target的一个数,讲此行标记为rowInd

2.从rowInd开始再进行二分查找

复杂度

思路1:

时间复杂度:

O ( l o g m n ) O(logmn) O(logmn)

空间复杂度:

O ( m n ) O(mn) O(mn)

思路2:

时间复杂度:

O ( l o g m n ) O(logmn) O(logmn)

空间复杂度:

O ( 1 ) O(1) O(1)

Code

思路1:

cpp 复制代码
class Solution {
public:
    /**
     * Binary Search
     * 
     * @param matrix Given array
     * @param target Given target number
     * @return bool
     */
    bool searchMatrix(vector<vector<int>> &matrix, int target) {
        int row = matrix.size();
        if (row == 0) {
            return false;
        }
        int col = matrix[0].size();
        int left = 0;
        int right = row * col - 1;
        vector<int> array(row * col);
        while (left <= right) {
            int mid = left + (right - left) / 2;
            if (matrix[mid / col][mid % col] == target) {
                return true;
            } else if (matrix[mid / col][mid % col] > target) {
                right = mid - 1;
            } else if (matrix[mid / col][mid % col] < target) {
                left = mid + 1;
            }
        }
        return false;
    }
};

思路2:

cpp 复制代码
class Solution {
 public:
     /**
      * Binary Search
      *
      * @param matrix Given array
      * @param target Given target number
      * @return bool
      */
     bool searchMatrix(vector<vector<int>>& matrix, int target) {
         int row = matrix.size();
         if (row == 0) {
             return false;
         }
         int col = matrix[0].size();
         int left = 0;
         int right = row - 1;
         while (left <= right) {
             int mid = left + (right - left) / 2;
             if (matrix[mid][0] == target) {
                 return true;
             } else if (matrix[mid][0] > target) {
                 right = mid - 1;
             } else if (matrix[mid][0] < target) {
                 left = mid + 1;
             }
         }
         // Check out of bounds
         if (right < 0) {
             return false;
         }
         int rowIdx = right;
         left = 0;
         right = col - 1;
         while (left <= right) {
             int mid = left + (right - left) / 2;
             if (matrix[rowIdx][mid] == target) {
                 return true;
             } else if (matrix[rowIdx][mid] > target) {
                 right = mid - 1;
             } else if (matrix[rowIdx][mid] < target) {
                 left = mid + 1;
             }
         }
         return false;
     }
 };
相关推荐
随意起个昵称2 小时前
区间dp-基础题目1(石子合并)
算法·动态规划
吞下星星的少年·-·3 小时前
线段树模板
算法
段一凡-华北理工大学3 小时前
2026 高炉炼铁智能化技术全景与演进路径~系列文章11:演进路径与行业未来
大数据·网络·人工智能·算法·工业智能体·高炉炼铁智能化
叶小鸡3 小时前
小鸡玩算法-力扣HOT100-多维动态规划
算法·leetcode·动态规划
星马梦缘4 小时前
aaaaa
数据结构·c++·算法
菜菜的顾清寒4 小时前
力扣HOT100(42)链表-随机链表的复制
算法·leetcode·链表
lqqjuly4 小时前
模型剪枝与稀疏化:理论、算法与可运行实现
人工智能·算法·剪枝
逻辑君5 小时前
Foresight研究报告【20260011】
人工智能·线性代数·算法·矩阵
珊瑚里的鱼5 小时前
【动态规划】不同路径Ⅱ
算法·动态规划
适应规律6 小时前
【无标题】
人工智能·python·算法