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

Problem: 74. 搜索二维矩阵

文章目录

题目描述

思路

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

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

2.对应的映射关系是array[mid] == mar[mid / n][mid % 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;
     }
 };
相关推荐
励志要当大牛的小白菜30 分钟前
ART配对软件使用
开发语言·c++·qt·算法
qq_5139704433 分钟前
力扣 hot100 Day56
算法·leetcode
PAK向日葵1 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱喝矿泉水的猛男4 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao4 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
YouQian7724 小时前
Traffic Lights set的使用
算法
go54631584656 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae6 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法
大锦终6 小时前
【算法】前缀和经典例题
算法·leetcode
想变成树袋熊6 小时前
【自用】NLP算法面经(6)
人工智能·算法·自然语言处理