力扣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;

    }
};
相关推荐
Liu628883 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
AI科技星4 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
参.商.4 小时前
【Day41】143. 重排链表
leetcode·golang
条tiao条4 小时前
KMP 算法详解:告别暴力匹配,让字符串匹配 “永不回头”
开发语言·算法
干啥啥不行,秃头第一名4 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
zzh940775 小时前
Gemini 3.1 Pro 硬核推理优化剖析:思维织锦、动态计算与国内实测
算法
2301_807367195 小时前
C++中的解释器模式变体
开发语言·c++·算法
愣头不青5 小时前
617.合并二叉树
java·算法
MIUMIUKK6 小时前
双指针三大例题
算法
灵感__idea6 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法