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;
    }
};
相关推荐
丁浩6663 小时前
Python机器学习---2.算法:逻辑回归
python·算法·机器学习
伏小白白白3 小时前
【论文精度-2】求解车辆路径问题的神经组合优化算法:综合展望(Yubin Xiao,2025)
人工智能·算法·机器学习
无敌最俊朗@4 小时前
数组-力扣hot56-合并区间
数据结构·算法·leetcode
囚生CY4 小时前
【速写】优化的深度与广度(Adam & Moun)
人工智能·python·算法
码农多耕地呗5 小时前
力扣94.二叉树的中序遍历(递归and迭代法)(java)
数据结构·算法·leetcode
微笑尅乐5 小时前
BFS 与 DFS——力扣102.二叉树的层序遍历
leetcode·深度优先·宽度优先
懒羊羊不懒@5 小时前
Java基础语法—最小单位、及注释
java·c语言·开发语言·数据结构·学习·算法
白云千载尽6 小时前
leetcode 912.排序数组
算法·leetcode·职场和发展
哆啦刘小洋6 小时前
Tips:预封装约束的状态定义
算法
代码充电宝6 小时前
LeetCode 算法题【简单】290. 单词规律
java·算法·leetcode·职场和发展·哈希表