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;
    }
相关推荐
小樱花的樱花44 分钟前
C++ new和delete用法详解
linux·开发语言·c++
努力的章鱼bro3 小时前
操作系统-FileSystem
c++·操作系统·risc-v·filesystem
96773 小时前
cURL curl
c++
一匹电信狗3 小时前
【Linux我做主】进程程序替换和exec函数族
linux·运维·服务器·c++·ubuntu·小程序·开源
会编程的土豆3 小时前
【数据结构与算法】二叉树从建立开始
数据结构·c++·算法
_日拱一卒4 小时前
LeetCode:最大子数组和
数据结构·算法·leetcode
:mnong4 小时前
Superpowers 项目设计分析
java·c语言·c++·python·c#·php·skills
信奥胡老师4 小时前
P1255 数楼梯
开发语言·数据结构·c++·学习·算法
A.A呐5 小时前
【C++第二十一章】set与map封装
开发语言·c++
96775 小时前
C++多线程2 如何优雅地锁门 (lock_guard) 多线程里的锁的种类
java·开发语言·c++