【leetcode100-021】【矩阵】搜索二维矩阵 II

news/2024/7/23 18:34:44 标签: 算法

【题干】

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

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

【思路】

以右上角为起点斜着看这个矩阵,会发现,这是一颗二叉搜索树。

那么我们就从右上角(0,n−1)处开始搜索。

在每一步的搜索过程中,如果我们位于位置(x,y),那么我们希望在以matrix 的左下角为左下角、以(x,y) 为右上角的矩阵中进行搜索,即行的范围为[x,m−1],列的范围为[0,y]:

  • 如果matrix[x,y]=target,说明搜索完成;
  • 如果matrix[x,y]>target,由于每一列的元素都是升序排列的,那么在当前的搜索矩阵中,所有位于第y列的元素都是严格大于target的,y--;
  • 如果matrix[x,y]<target,由于每一行的元素都是升序排列的,那么在当前的搜索矩阵中,所有位于第x行的元素都是严格小于target的,x++;
  • 在搜索的过程中,如果我们超出了矩阵的边界,那么说明矩阵中不存在target。

【题解】

class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m = matrix.size(), n = matrix[0].size();
        int x = 0, y = n - 1;
        while (x < m && y >= 0) {
            if (matrix[x][y] == target) {
                return true;
            }
            if (matrix[x][y] > target) {
                --y;
            }
            else {
                ++x;
            }
        }
        return false;
    }
};


http://www.niftyadmin.cn/n/5288551.html

相关文章

模型系列:聚类_五个聚类算法比较综述

文章目录 介绍1. 聚类算法的类型2. 设置2.1 数据集2.2 导入库2.3 导入数据2.4 一些可视化展示2.5 特征工程2.6 异常值检测异常值检测模型选择 2.7 数据伸缩 3. 确定最佳聚类数3.1 肘部法则3.2 Silhouette方法3.3 系统树图 4. K-Means4.1 K-Means的优缺点优点&#xff1a;缺点&a…

SpringIOC之AbstractXmlApplicationContext

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

在k8s中使用cert-manager部署gitlab集群

写在前面的话&#xff1a;前面有详细的分享过在k8s集群中部署gitlab&#xff0c;不过当时使用gitlab的访问证书是阿里云上免费的ssl证书&#xff0c;今天特意专门介绍下另外一种基于cert-manager发布自签证书的方式实现部署gitlab到k8s集群中。 往期gitlab部署系列如&#xff1…

验证 Mixtral-8x7B-Instruct-v0.1 和 LangChain SQLDatabaseToolkit 的集成效果

验证 Mixtral-8x7B-Instruct-v0.1 和 LangChain SQLDatabaseToolkit 的集成效果 0. 背景1. 验证环境说明2. 验证开始2-1. 准备测试数据库2-2. 读取环境配置信息2-3. 导入依赖包2-3. 创建 SQLDatabaseToolkit 对象和 AgentExecutor 对象2-4. 第1个测试 - 描述一个表2-5. 第2个测…

uni-app 命令行创建

1. 首先创建项目&#xff0c;命令如下: npx degit dcloudio/uni-preset-vue#vite-ts uni-app-demo如果出现报错&#xff0c;如下图. 大概率就是没有目录C:\Users\Administrator\AppData\Roaming\npm 解决办法&#xff1a; 创建目录 C:\Users\Administrator\AppData\Roaming\n…

MongoDB聚合管道:$match

$match是聚合管道中最常用的阶段之一&#xff0c;用于过滤管道中的文档&#xff0c;只允许符合条件的文档进入到管道的下一阶段。 语法 {$match:{<query>}}使用举例 创建articles文档&#xff0c;并加入下面的数据 { "_id" : ObjectId("512bc95fe835e…

光伏发电模式中,分布式和集中式哪种更受欢迎?

光伏发电系统就是将太阳辐射转化为电能的一种发电系统&#xff0c;越来越受到人们的关注和重视。光伏发电领域中&#xff0c;分为分布式光伏发电和集中式光伏发电两种不同的发电模式&#xff0c;有什么区别&#xff1f;哪一种更受欢迎&#xff1f; 分布式光伏发电&#xff1a;…

大语言模型激活函数绘图

使用torch中的激活函数&#xff0c;绘制多个激活函数多一个图中对比展示 引入依赖 import torch from torch.nn import functional as F import matplotlib.pyplot as plt plt.rcParams[font.sans-serif] [Arial Unicode MS]定义单个曲线图的绘制函数 def draw_single_plot…