力扣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;
     }
 };
相关推荐
_x_w5 分钟前
【17】数据结构之图及图的存储篇章
数据结构·python·算法·链表·排序算法·图论
anscos12 分钟前
Actran声源识别方法连载(二):薄膜模态表面振动识别
人工智能·算法·仿真软件·actran
-优势在我34 分钟前
LeetCode之两数之和
算法·leetcode
WaitWaitWait0138 分钟前
LeetCode每日一题4.17
算法·leetcode
小媛早点睡38 分钟前
贪心算法day9(合并区间)
算法·贪心算法
DataFunTalk1 小时前
Foundation Agent:深度赋能AI4DATA
前端·后端·算法
不是AI1 小时前
【Java编程】【计算机视觉】一种简单的图片加/解密算法
java·算法·计算机视觉
明月看潮生1 小时前
青少年编程与数学 02-016 Python数据结构与算法 23课题、分布式算法
分布式·python·算法·青少年编程·编程与数学
冠位观测者2 小时前
【Leetcode 每日一题】2176. 统计数组中相等且可以被整除的数对
数据结构·算法·leetcode
幼儿园园霸柒柒2 小时前
第七章:7.2求方程a*x*x+b*x+c=0的根,用3个函数,分别求当:b*b-4*a*c大于0、等于0和小于0时的根并输出结果。从主函数输入a、b、c的值
c语言·开发语言·算法·c#