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)。

代码:

cpp 复制代码
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;
    }
};
相关推荐
草莓熊Lotso15 小时前
MySQL 内置函数指南:日期、字符串、数学函数实战
android·java·linux·运维·数据库·c++·mysql
ab15151715 小时前
3.21二刷基础125、122、130,完成进阶65
开发语言·c++·算法
j_xxx404_15 小时前
力扣--分治(快速排序)算法题I:颜色分类,排序数组
数据结构·c++·算法·leetcode·排序算法
艾莉丝努力练剑15 小时前
【Linux信号】Linux进程信号(上):信号产生方式和闹钟
linux·运维·服务器·c++·人工智能·ubuntu·云原生
wengqidaifeng15 小时前
备战蓝桥杯----C/C++组 (一)数据结构与STL讲解(中):树、二叉树与堆——从层次结构到优先队列的进阶之路
c语言·c++·蓝桥杯
2301_7665586515 小时前
矩阵跃动OpenClaw龙虾机器人:本地AI智能体+GEO优化,企业流量自动化落地
人工智能·矩阵·机器人
承渊政道15 小时前
C++学习之旅【IO库相关内容介绍】
c语言·开发语言·c++·学习·macos·visual studio
小年糕是糕手15 小时前
【35天从0开始备战蓝桥杯 -- Day5】
数据结构·数据库·c++·算法·蓝桥杯
炸膛坦客15 小时前
单片机/C/C++八股:(十七)C++ 中指针和引用的区别
c语言·开发语言·c++
草莓熊Lotso16 小时前
Linux IPC 进阶:System V 消息队列与信号量(含内核管理深度解析)
linux·运维·服务器·数据库·c++·人工智能·mysql