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

    }
};
相关推荐
sml259(劳改版)2 分钟前
(PTA) L2-011-L2-015
数据结构·算法
阿里云大数据AI技术28 分钟前
阿里云 AI 搜索开放平台:从算法到业务——AI 搜索驱动企业智能化升级
大数据·人工智能·算法
whltaoin1 小时前
贪心算法:部分背包问题深度解析
算法·贪心算法
不眠之夜1 小时前
龟兔赛跑:快慢指针法详解(Floyd's Tortoise and Hare Algorithm)
算法
零零壹111 小时前
Apipost自定义函数深度实战:灵活处理参数值秘籍
算法·面试·github
搞程序的心海1 小时前
当机器学习遇见购物车分析:FP-Growth算法全解析
算法
Ludicrouers1 小时前
【Leetcode-Hot100】字母异位词分组
算法·leetcode·职场和发展
爱笑的Sunday1 小时前
【LeetCode 题解】数据库:1321.餐馆营业额变化增长
数据库·sql·leetcode
aw3442 小时前
tiny_dnn_test250101
人工智能·算法·dnn
Bryce-Lin2 小时前
深度学习、图像算法学习记录
深度学习·学习·算法