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

    }
};
相关推荐
IMPYLH2 分钟前
HTML 的 <abbr> 元素
前端·算法·html
leo__52012 分钟前
小波特征与模糊支持向量机(FSVM)的脑电信号分类方法
算法·支持向量机·分类
wabs66616 分钟前
关于动态规划【纯粹的0-1背包需要思考的问题】
算法·动态规划
小小编程路18 分钟前
字符串转数字时,可能会遇到哪些问题?
java·开发语言·算法
rit843249933 分钟前
MATLAB近红外光谱预处理:平滑与求导(MSV方法)
数据结构·算法·matlab
蚂蚁数据AntData38 分钟前
从ChatBI到业务记忆:重新定义数据智能的生产力边界
大数据·网络·数据库·人工智能·算法
_日拱一卒39 分钟前
LeetCode:22括号生成
算法·leetcode·职场和发展
cfm_291440 分钟前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
郝学胜_神的一滴1 小时前
干货版《算法导论》09:让哈希表稳如泰山的终极解法
数据结构·算法
CC数学建模1 小时前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题C题:创业社区规划与资源配置优化问题完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模