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

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

    }
};

相关文章:

  • 前端js题目大全
  • 计算机视觉算法实战——表面缺陷检测(主页有源码)
  • UE引擎游戏加固方案解析
  • 一文了解PLM项目管理系统
  • 51单片机-定时器中断
  • 「正版软件」PDF Reader - 专业 PDF 编辑阅读工具软件
  • SpringBoot+Vue3-学习笔记
  • java泛型
  • 交通物联网:概念、历史、现状与展望
  • Redis 字符串(String)
  • 【分布式理论11】分布式协同之分布式事务(一个应用操作多个资源):从刚性事务到柔性事务的演进
  • Vue 监听属性(watch)
  • MySQL数据库入门到大蛇尚硅谷宋红康老师笔记 高级篇 part 2
  • 嵌入式工业级显示器在环保垃圾柜设备中发挥着至关重要的作用
  • Linux 实操篇 组管理和权限管理、定时任务调度、Linux磁盘分区和挂载
  • Linux-C/C++《C/9、信号:基础》(基本概念、信号分类、信号传递等)
  • 2025年archlinux tigervnc分辨率设置不生效的问题
  • Deepseek 与 ChatGPT:AI 浪潮中的双子星较量
  • YOLOv11-ultralytics-8.3.67部分代码阅读笔记-loaders.py
  • 机器视觉--图像的运算(减法)
  • 做网站的专业叫什么/国内优秀个人网站欣赏
  • 平凉建设局网站/服务器租用
  • 专门做企业名录的网站/品牌策划方案
  • 色轮配色网站/淘宝指数官网入口
  • 如何把地图放到网站上/如何优化网络速度
  • 保山网站制作/100种找客户的方法