当前位置: 首页 > article >正文

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

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

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

解题思路:

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

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;

    }
};


http://www.kler.cn/a/554860.html

相关文章:

  • L0G3000 Git 基础知识
  • 计算机毕业设计Python农产品推荐系统 农产品爬虫 农产品可视化 农产品大数据(源码+LW文档+PPT+讲解)
  • 嵌入式编程——数据结构与linux编程
  • Brave132编译指南 MacOS篇 - 获取源代码(三)
  • 23种设计模式 - 桥接模式
  • 本地部署DeepSeek的硬件配置建议
  • 项目设置内网 IP 访问实现方案
  • 微软宣布 Windows 11 将不再免费升级:升级需趁早
  • 解决webpack4 import 动态导入组件打包报错
  • 第4章 信息系统架构(四)
  • Android GreenDAO 适配 AGP 8.0+
  • web网络安全:SQL 注入攻击
  • 第150场双周赛:好数字之和、分割正方形 Ⅰ、分割正方形 Ⅱ、最短匹配字符串
  • HBase的安全性考量:保护你的数据不受威胁
  • 蓝桥杯学习大纲
  • DeepSeek部署到本地(解决ollama模型下载失败问题)
  • 【2025最新版】Chrome谷歌浏览器如何能恢复到之前的旧版本
  • 基于单片机的智能网控风扇设计
  • C++:类与对象,定义类和构造函数
  • 【ISO 14229-1:2023 UDS诊断(ECU复位0x11服务)测试用例CAPL代码全解析⑩】