LeetCode热题100——240.搜索二维矩阵 II(题目+题解+答案)

题目:

编写一个高效的算法来搜索 m ×n 矩阵 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

题解:

方法:逐行二分查找

由于矩阵的每一行都是升序排列的,我们可以利用这一性质,对每一行分别进行二分查找,判断 target 是否存在于该行中。

具体步骤:

1.获取矩阵的行数 m 和列数 n。

2.遍历每一行(i = 0 到 m-1):

  • 若 target 小于当前行的第一个元素,或者大于当前行的最后一个元素,说明目标值不可能存在于这一行,直接跳过(剪枝)。
  • 否则,对该行使用二分查找(binary_search)判断 target 是否在该行中。
  • 若找到,立即返回 true。

3.若遍历完所有行都没有找到,返回 false。

binary_search函数:

binary_search 是 C++ 标准库 <algorithm> 中提供的一个二分查找函数,用于在有序区间内快速判断某个值是否存在。

cpp 复制代码
bool binary_search( ForwardIt first, ForwardIt last, const T& value );
bool binary_search( ForwardIt first, ForwardIt last, const T& value, Compare comp );
参数说明:
  • first, last:指定要搜索的区间 [first, last)(左闭右开)。区间内的元素必须已经按升序(或指定的比较规则)排好序。
  • value:要查找的目标值。
  • comp:可选的比较函数(或函数对象),用于定义元素间的顺序关系。默认使用 operator<。
返回值

如果区间内存在元素与 value 相等(按比较规则等价),返回 true;否则返回 false。

答案:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m=matrix.size();//行数
        int n=matrix[0].size();//列数
        for(int i=0;i<m;i++){
            //剪枝:若目标值小于当前行最小值 或 大于当前行最大值,则跳过
            if(target<matrix[i][0]||target>matrix[i][n-1]) continue;
            //在当前行进行二分查找
            if(binary_search(matrix[i].begin(),matrix[i].end(),target))
                return true;
        }
        return false;
    }
};
相关推荐
codebrick1 小时前
408 数据结构:快排 / 堆排 / 归并 / 希尔 等排序算法对比(复杂度、稳定性、真题考点
数据结构·考研·算法·排序算法·408
纤纡.2 小时前
基于 TextRNN 的微博情绪分类系统实现与解析
人工智能·算法·分类·数据挖掘
hehelm2 小时前
string的模拟实现
数据结构·算法
白羊by2 小时前
逻辑回归与Softmax的区别
算法·机器学习·逻辑回归
极客智造2 小时前
C++ 类模板完全深度指南:泛型编程、特化、分离编译与工程实践
c++
Tisfy2 小时前
LeetCode 3761.镜像对之间最小绝对距离:哈希表(维护左,枚举右)
算法·leetcode·散列表·题解
小鱼~~2 小时前
逻辑回归简介
算法·机器学习·逻辑回归
黎阳之光2 小时前
黎阳之光受邀出席上海口岸联合会2026智慧口岸研讨班 无感通关方案获盛赞
大数据·人工智能·算法·安全·数字孪生
TU^2 小时前
C++11(二)
c++·算法