74. 搜索二维矩阵【二分法】【C++】

题目描述

搜索二维矩阵
给你一个满足下述两条属性的 m x n 整数矩阵:
每行中的整数从左到右按非严格递增顺序排列。
每行的第一个整数大于前一行的最后一个整数。
给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。
示例 1:
在这里插入图片描述

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true
示例 2:
在这里插入图片描述

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
输出:false
提示:
m == matrix.length
n == matrix[i].length
1 <= m, n <= 100
-104 <= matrix[i][j], target <= 104

思路

本题是二分搜索的变形,常规的二分搜索是一个一维数组,而本题是一个二维数组,但是依然可以使用一维数组的思路,关键点:将二维坐标与一位坐标进行转化,比如:34的二维数组其实可以看成121的一维数组,最中间的数mid是5((0+12-1) / 2 == 5),对应二维数组行数1(5 / 4==1),列数5(5 % 4 == 1)。

代码:

class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int row = matrix.size();  //行大小
        int col = matrix[0].size();    //列大小
        int len = row * col;    //一维数组长度
        int left = 0;     //左右指针
        int right = len - 1;  //左闭右闭
        while (left <= right) { 
            int mid_old = (right - left) / 2 + left;  //一维数组的坐标
            int mid_x = mid_old / col;     //  计算二维数组的坐标
            int mid_y = mid_old % col; 
            if (matrix[mid_x][mid_y] < target) {
                left = mid_old + 1;
            }else if (matrix[mid_x][mid_y] > target) {
                right = mid_old - 1;
            }else {
                return true;
            }
        }
        return false;
    }
};

相关推荐

  1. 74.搜索矩阵

    2024-07-09 18:28:03       69 阅读
  2. 74. 搜索矩阵

    2024-07-09 18:28:03       52 阅读
  3. 74. 搜索矩阵

    2024-07-09 18:28:03       49 阅读
  4. 74. 搜索矩阵

    2024-07-09 18:28:03       22 阅读
  5. 【算法题】74. 搜索矩阵

    2024-07-09 18:28:03       41 阅读
  6. leetcode 74.搜索矩阵

    2024-07-09 18:28:03       46 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-09 18:28:03       51 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-09 18:28:03       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-09 18:28:03       44 阅读
  4. Python语言-面向对象

    2024-07-09 18:28:03       55 阅读

热门阅读

  1. 如何编译ffmpeg支持h265(hevc)?

    2024-07-09 18:28:03       27 阅读
  2. 【AI应用探讨】—Boosting应用场景

    2024-07-09 18:28:03       22 阅读
  3. 设计模式之单例模式

    2024-07-09 18:28:03       24 阅读
  4. EXCEL VBA发邮件,实现自动化批量发送

    2024-07-09 18:28:03       23 阅读
  5. 网络“ping不通”,如何排查和解决呢?

    2024-07-09 18:28:03       22 阅读
  6. window wsl安装ubuntu

    2024-07-09 18:28:03       22 阅读
  7. 5、Redis 缓存设计相关知识点

    2024-07-09 18:28:03       26 阅读
  8. 面试题 14- I. 剪绳子

    2024-07-09 18:28:03       30 阅读
  9. 机器学习 - 比较检验

    2024-07-09 18:28:03       25 阅读
  10. Mac OS系统中Beyond Compare 4破解方式

    2024-07-09 18:28:03       25 阅读