力扣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;
     }
 };
相关推荐
山北雨夜漫步几秒前
机器学习 Day18 Support Vector Machine ——最优美的机器学习算法
人工智能·算法·机器学习
拼好饭和她皆失13 分钟前
算法加训之最短路 上(dijkstra算法)
算法
瓦力wow3 小时前
c语言 写一个五子棋
c语言·c++·算法
X-future4263 小时前
院校机试刷题第六天:1134矩阵翻转、1052学生成绩管理、1409对称矩阵
线性代数·算法·矩阵
Codeking__3 小时前
前缀和——中心数组下标
数据结构·算法
爱喝热水的呀哈喽3 小时前
非线性1无修
算法
花火QWQ3 小时前
图论模板(部分)
c语言·数据结构·c++·算法·图论
Pacify_The_North4 小时前
【进程控制二】进程替换和bash解释器
linux·c语言·开发语言·算法·ubuntu·centos·bash
轮到我狗叫了4 小时前
力扣310.最小高度树(拓扑排序,无向图),力扣.加油站力扣.矩阵置零力扣.二叉树中的最大路径和
算法·leetcode·职场和发展
埃菲尔铁塔_CV算法4 小时前
深度学习驱动下的目标检测技术:原理、算法与应用创新(二)
深度学习·算法·目标检测