Leetcode 240. 搜索二维矩阵 II 矩阵 / 二分

原题链接: Leetcode 240. 搜索二维矩阵 II


解法一:排除法

参考 【图解】排除法,一图秒懂!(Python/Java/C++/C/Go/JS/Rust)

从右上角:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m=matrix.size();
        int n=matrix[0].size();
        int min_num=matrix[0][0];
        int max_num=matrix[m-1][n-1];
        if(target<min_num || target>max_num) return false;
        int i=0,j=n-1;
        while(i<m && j>=0){
            if( matrix[i][j]==target) {
                return true;
            }
            if( matrix[i][j]<target){
                i++;
            }
            else{
                j--;
            }
        }
        return false;
    }
};

从左下角:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m=matrix.size();
        int n=matrix[0].size();
        int min_num=matrix[0][0];
        int max_num=matrix[m-1][n-1];
        if(target<min_num || target>max_num) return false;
        int i=m-1,j=0;
        while(i>=0 && j<n){
            if( matrix[i][j]<target ){
                j++;
            }
            else if( matrix[i][j]>target ){
                i--;
            }
            else return true;
        }
        return false;
    }
};

解法二:二分

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m=matrix.size();
        int n=matrix[0].size();
        int min_num=matrix[0][0];
        int max_num=matrix[m-1][n-1];
        if(target<min_num || target>max_num) return false;
        for(auto row: matrix){
            auto it = lower_bound(row.begin(),row.end(),target);
            if (it != row.end() && *it==target) return true;
        }
        return false;
    }
};
相关推荐
老鼠只爱大米14 分钟前
LeetCode算法题详解 11:盛最多水的容器
leetcode·面试题·双指针·盛最多水的容器·面积最大化
MM_MS26 分钟前
Halcon控制语句
java·大数据·前端·数据库·人工智能·算法·视觉检测
mit6.82439 分钟前
山脉二分找中值|子集型回溯
算法
乃瞻衡宇1 小时前
Agent Skills 完全指南:让你的 AI Agent 拥有超能力
算法
mit6.8241 小时前
pair<int, TreeNode*> dfs
算法
进击中的小龙2 小时前
基于rtklib的载波相位平滑伪距
c语言·算法·数学建模·gitee
初晴や2 小时前
【C++】图论:基础理论与实际应用深入解析
c++·算法·图论
李泽辉_2 小时前
深度学习算法学习(五):手动实现梯度计算、反向传播、优化器Adam
深度学习·学习·算法
李泽辉_2 小时前
深度学习算法学习(一):梯度下降法和最简单的深度学习核心原理代码
深度学习·学习·算法
꧁Q༒ོγ꧂2 小时前
算法详解---大纲
算法