LeetCode 240. 搜索二维矩阵 II

原题链接:

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题面:

编写一个高效的算法来搜索 m xn 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:

  • 每行的元素从左到右升序排列。
  • 每列的元素从上到下升序排列。

示例 1:

复制代码
输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 5
输出:true

示例 2:

复制代码
输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 20
输出:false

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= n, m <= 300
  • -10^9 <= matrix[i][j] <= 10^9
  • 每行的所有元素从左到右升序排列
  • 每列的所有元素从上到下升序排列
  • -109 <= target <= 109

解题思路:

可以很容易想到,当数组中选取的数字小于要查找的数字,则根据该题二维数组的排序规则,我们要找的数字可能在当前选取位置的右边或者下边,同理,如果选取的数字大于要查找的数字,那么要查找的数字可能在当前选取位置的左边或者上边。

在以上分析中,由于要查找的数字相对于选取位置有可能在两个区域中出现,并且这两个区域还存在重叠,所以单纯的用这个规律进行搜索似乎是不太可行的,并不能十分有效的提高搜索效率。

我们考虑从右上角开始搜索,如果该数字等于要查找的数字,则结束查找。如果该数字大于要查找的数字,则这一列都不可能符合,所以排除这一列。如果该数字小于要查找的数字,那么按照规律我们应该往右或者往下,但是右边的列是已经被我们排除过的,所以往下,即将当前行也排除掉了。这样每一步都可以缩小查找的范围,直到找到要查找的数字或者查找范围为空。

时间复杂度为O(m+n),m为矩阵行数,n为矩阵列数。

空间复杂度为O(1)。

代码(C):

cpp 复制代码
bool searchMatrix(int** matrix, int matrixSize, int* matrixColSize, int target){
    int m = matrixSize;
    int n = *matrixColSize;
    int row = 0;
    int col = n - 1;
    while (row < m && col >= 0) {
        if (matrix[row][col] == target) {
            return true;
        }
        if (matrix[row][col] > target) {
            col--;
        } else {
            row++;
        }
    }
    return false;
}
相关推荐
爱吃生蚝的于勒1 小时前
C语言内存函数
c语言·开发语言·数据结构·c++·学习·算法
ChoSeitaku6 小时前
链表循环及差集相关算法题|判断循环双链表是否对称|两循环单链表合并成循环链表|使双向循环链表有序|单循环链表改双向循环链表|两链表的差集(C)
c语言·算法·链表
DdddJMs__1356 小时前
C语言 | Leetcode C语言题解之第557题反转字符串中的单词III
c语言·leetcode·题解
Fuxiao___6 小时前
不使用递归的决策树生成算法
算法
我爱工作&工作love我7 小时前
1435:【例题3】曲线 一本通 代替三分
c++·算法
白-胖-子7 小时前
【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字
开发语言·c++·算法·蓝桥杯·等考·13级
workflower7 小时前
数据结构练习题和答案
数据结构·算法·链表·线性回归
好睡凯7 小时前
c++写一个死锁并且自己解锁
开发语言·c++·算法
Sunyanhui17 小时前
力扣 二叉树的直径-543
算法·leetcode·职场和发展
一个不喜欢and不会代码的码农7 小时前
力扣105:从先序和中序序列构造二叉树
数据结构·算法·leetcode