240 搜索二维矩阵 II

解题思路:
\qquad 解这道题最重要的是如何利用从左到右、从上到下为升序的性质,快速找到目标元素。
\qquad 如果从左上角开始查找,如果当前matrix[i][[j] < target,可以向右、向下扩展元素都是升序,但选择哪个方向是不明确的,很容易陷入局部最优而找到不到全局最优解。
\qquad 所以需要改变查找的起始位置,使一个方向为升序,而另一个为降序,比如右上角,向下为升序而向左为降序。当matrix[i][j] > target时,向左移动;当matrix[i][j] < target时,向下移动,不断逼近目标,且遍历路径不会重复,时间复杂度为 O ( m + n ) O(m+n) O(m+n)。

cpp 复制代码
bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int i = 0, j = matrix[0].size()-1;
        while(i < matrix.size() && j >= 0)
        {
            if(matrix[i][j] == target) return true;
            else if(matrix[i][j] < target) i++;
            else j--;
        }
        return false;
    }
相关推荐
良木生香几秒前
【C语言进阶】文件操作的相关详解(1):
c语言·数据结构·c++
Larry_Yanan1 分钟前
Qt安卓开发(三)双摄像头内嵌布局
android·开发语言·c++·qt·ui
玖釉-12 分钟前
[Vulkan 学习之路] 01 - 迈入高性能图形开发的大门 (Windows 环境搭建)
c++·windows·图形渲染
CSDN_RTKLIB1 小时前
【字符编码】字符串处理流程
c++
有一个好名字1 小时前
力扣-奇偶链表
算法·leetcode·链表
wxm6311 小时前
力扣算法题(C++):1、2
java·算法·leetcode
带土11 小时前
8. C++ explicit 关键字
开发语言·c++
im_AMBER1 小时前
Leetcode 103 反转链表 II
数据结构·c++·笔记·学习·算法·leetcode
十五年专注C++开发2 小时前
CMake基础:foreach详解
linux·c++·windows·cmake·跨平台编译
小黄鸭code2 小时前
C++ 算法笔试题(常见算法版)
c++·算法·排序算法