【LeetCode热题100】74. 搜索二维矩阵(二分)

一.题目要求

给你一个满足下述两条属性的 m x n 整数矩阵:

  • 每行中的整数从左到右按非严格递增顺序排列。
  • 每行的第一个整数大于前一行的最后一个整数。

给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。

二.题目难度

中等

三.输入样例

示例 1:

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3

输出:true

示例 2:

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13

输出:false

提示:

m == matrix.length

n == matrix[i].length

1 <= m, n <= 100

-104 <= matrix[i][j], target <= 104

四.解题思路

解法1:先对每列第一个元素二分,再二分查找符合条件的某一行。时间复杂度 O ( l o g m + l o g n ) O(logm+logn) O(logm+logn)

解法2:类似BST,从右上角开始查找,写法较简单,时间复杂度 O ( l o g ( m ∗ n ) ) O(log(m∗n)) O(log(m∗n))

五.代码实现

解2:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {

        int row = matrix.size();
        int col = matrix[0].size();

        for (int i = 0, j = col - 1; i < row && j >= 0;
             matrix[i][j] > target ? j-- : i++) {
            if (matrix[i][j] == target)
                return true;
        }
        return false;
    }
};

解1:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {

        int rowl = 0;
        int rowr = matrix.size() - 1;
        int rowmid = (rowl + rowr) / 2;
        while (rowl <= rowr) {
            rowmid = (rowl + rowr) / 2;
            if (matrix[rowmid][0] == target)
                return true;
            if (matrix[rowmid][0] > target) {
                rowr -= 1;
            }
            else if (matrix[rowmid][0] < target) {
                rowl += 1;
            }
        }
        int l = 0;
        int r = matrix[0].size() - 1;
        int m = (l + r) / 2;
        int row;
        if (rowl > rowr)
            row = rowr;
        else
            row = rowl;
        if (row < 0 || row >= matrix.size())
            return false;

        while (l <= r) {
            m = (l + r) / 2;

            if (matrix[row][m] == target)
                return true;

            if (matrix[row][m] > target) {
                r -= 1;
            } else if (matrix[row][m] < target) {
                l += 1;
            }
        }
        return false;
    }
};

六.题目总结

--

相关推荐
ゞ 正在缓冲99%…14 分钟前
leetcode101.对称二叉树
算法
YuTaoShao1 小时前
【LeetCode 每日一题】3000. 对角线最长的矩形的面积
算法·leetcode·职场和发展
2zcode1 小时前
基于Matlab可见光通信系统中OOK调制的误码率性能建模与分析
算法·matlab·php
纵有疾風起1 小时前
数据结构中的排序秘籍:从基础到进阶的全面解析
c语言·数据结构·算法·排序算法
纪元A梦1 小时前
贪心算法应用:推荐冷启动问题详解
算法·贪心算法
听风说雨的人儿1 小时前
腾讯面试题之编辑距离
算法
Lululaurel2 小时前
机器学习系统框架:核心分类、算法与应用全景解析
人工智能·算法·机器学习·ai·分类
愚润求学2 小时前
【贪心算法】day8
c++·算法·leetcode·贪心算法
递归尽头是星辰2 小时前
双指针与滑动窗口算法精讲:从原理到高频面试题实战
算法·双指针·滑动窗口·子串/子数组问题
听情歌落俗3 小时前
MATLAB3-1变量-台大郭彦甫
开发语言·笔记·算法·matlab·矩阵