力扣hot100 ——搜索二维矩阵 || m+n复杂度优化解法

编写一个高效的算法来搜索 m xn 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:

  • 每行的元素从左到右升序排列。
  • 每列的元素从上到下升序排列。

解题思路:

借助行和列有序特性,不断按行或者列缩小范围;途中数字表示每次执行,不同颜色框出的范围就是每次缩小后的区域,由于不是按行就是按列缩小,所以时间复杂度就是O(m+n)

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        // 边界缩小查找
        // 从右上角开始缩小;先水平调整,然后竖直缩小
        // 借助行和列有序特性,不断按行或者列缩小范围;由于不是按行就是按列缩小,所以时间复杂度就是O(m+n)
        int rows = matrix.size(),clos = matrix[0].size(); // row 行上限  clo 列上限
        int row = 0,clo = clos - 1;
        if(target > matrix[rows-1][clos - 1]){
            return false;
        }
        while(row < rows && clo >= 0){
            if(matrix[row][clo] == target){
                return true;
            }
            else if(matrix[row][clo] > target){
                --clo;
            }
            else{
                ++row;
            }
        }
        return false;

    }
};
相关推荐
泽虞11 小时前
《C++程序设计》笔记p4
linux·开发语言·c++·笔记·算法
运维帮手大橙子12 小时前
算法相关问题记录
算法
小麦矩阵系统永久免费13 小时前
自动化运营|矩阵系统省心高效
运维·矩阵·自动化
MoRanzhi120313 小时前
9. NumPy 线性代数:矩阵运算与科学计算基础
人工智能·python·线性代数·算法·机器学习·矩阵·numpy
疯狂的Alex13 小时前
C++23特性全解析:从编译器支持矩阵到多维数组性能优化实战
rpc·矩阵·c++23
aaaaaaaaaaaaay13 小时前
代码随想录算法训练营第五十一天|99.岛屿数量 深搜 99.岛屿数量 广搜 100.岛屿的最大面积
算法·深度优先
hn小菜鸡14 小时前
LeetCode 2460.对数组执行操作
算法·leetcode·职场和发展
jghhh0114 小时前
HT16C21 驱动模拟I2C实现
单片机·嵌入式硬件·算法
自信的小螺丝钉14 小时前
Leetcode 148. 排序链表 归并排序
算法·leetcode·链表·归并
listhi52014 小时前
基于梯度下降、随机梯度下降和牛顿法的逻辑回归MATLAB实现
算法·matlab·逻辑回归