LeetCode刷题之搜索二维矩阵

2024 7/5 一如既往的晴天,分享几张拍的照片嘿嘿,好几天没做题了,在徘徊、踌躇、踱步。蝉鸣的有些聒噪了,栀子花花苞也都掉落啦,今天给他剪了枝,接回一楼来了。ok,做题啦!
在这里插入图片描述
图1、宿舍阳台摄,每天都是如此美景
在这里插入图片描述
图2、吃饭路上桥上摄
在这里插入图片描述
图3、桥的另一边摄
okok,做题啦!

1、题目描述

在这里插入图片描述

2、算法分析

要求设计一个高效的算法在矩阵中搜索我们想要的元素。我所能想到的就只有暴力解法:

 public boolean searchMatrix(int[][] matrix, int target) {
        for(int[] row : matrix ){
            for(int x : row){
                if(x == target){
                    return true;
                }
            }
        }
        return false;   
    }

暴力解法感觉很爽啊,思路简单。为什么简单的解法往往性能不简单呢?收益高的往往需要更多的付出呢?空间复杂度和时间复杂度往往不能正相关呢?一切似乎都与能量守恒有关。一切似乎都被设定,而我就是一个没有台词的NPC。哈哈,太tm矫情了,矫揉造作,继续想想有没有什么好的方法。
是有的,由于矩阵每一行都是升序排列的,所以我们遍历每一行后,再进行二分查找,看目标值是否在矩阵中。

3、代码

public boolean searchMatrix(int[][] matrix, int target) {
        // 遍历矩阵的每一行  
        for(int[] row : matrix){
            // 对当前行执行二分查找,寻找目标值
            int index = binarySearch(row, target);
            // 如果在当前行找到了目标值(即index >= 0),则返回true
            if(index >= 0){
                return true;
            }
        } 
        // 如果遍历完所有行都没有找到目标值,则返回false
        return false;
    }
    // 定义一个辅助方法,用于对一维数组进行二分查找  
    // 参数:nums是要搜索的一维数组,target是要搜索的目标值  
    // 返回值:如果找到目标值,则返回目标值在数组中的索引;如果没有找到,则返回-1
    public int binarySearch(int[] nums, int target){
        // 初始化查找范围的上下界
        int low = 0, high = nums.length - 1;
        // 当查找范围不为空时,进行查找
        while(low <= high){
            // 计算中间索引,防止溢出 
            int mid = (high - low) / 2 + low;
            // 获取中间元素的值
            int temp = nums[mid];
            // 如果中间元素等于目标值,则返回其索引
            if(temp == target){
                return mid;
            // 如果中间元素大于目标值,则在左半部分继续查找 
            }else if(temp > target){
                high = mid - 1;
            // 如果中间元素小于目标值,则在右半部分继续查找
            }else{
                low = mid + 1;
            } 
        }
        // 如果遍历完整个数组都没有找到目标值,则返回-1
        return -1;
    }

4、复杂度分析

  • 时间复杂度:O(mlogn)。对一行使用二分查找的时间复杂度为 O(logn),最多需要进行 m 次二分查找。
  • 空间复杂度:O(1)

5、Z形查找

okok,还有更妙的一个算法呢,本来打算不写了,发现这个算法妙得很啊,Z字形查找。
Z形查找:

  1. 选择起始搜索点:由于矩阵的每一行和每一列都是有序的,从矩阵的右上角(或左下角,取决于搜索策略)开始搜索是一个很好的选择。这里选择右上角是因为它允许我们同时利用行和列的排序特性。
  2. 比较与移动:在搜索过程中,我们不断地将当前元素与目标值进行比较。如果当前元素等于目标值,则搜索成功,返回true。如果当前元素大于目标值,由于列是升序的,我们可以确定目标值不可能在当前列的更上方(即更靠近矩阵顶部的位置),因此我们将搜索范围缩小到当前列的左方一列。相反,如果当前元素小于目标值,由于行是升序的,我们可以确定目标值不可能在当前行的更左方(即更靠近矩阵左侧的位置),因此我们将搜索范围缩小到当前行的下一行。
  3. 迭代搜索:重复上述比较与移动的过程,直到找到目标值或搜索范围为空(即已经遍历到矩阵的左下角或右上角之外的位置)。
public boolean searchMatrix(int[][] matrix, int target) {
         // 获取矩阵的行数和列数
        int m = matrix.length, n = matrix[0].length;
        // 初始化搜索的起始位置,从矩阵的右上角开始  
        // 选择右上角是因为这样可以同时利用行和列的排序特性来缩小搜索范围
        int x = 0, y = n - 1;
        // 当没有越界时,继续搜索
        while(x < m && y >= 0){
            // 如果当前元素等于目标值,则搜索成功,返回true 
            if(matrix[x][y] == target){
                return true;
            }
            // 如果当前元素大于目标值,由于列是升序的,所以目标值不可能在当前列的更上方  
            // 因此,将搜索范围缩小到当前列的左方一列 
            if(matrix[x][y] > target){
                y--;
            // 如果当前元素小于目标值,由于行是升序的,所以目标值不可能在当前行的更左方  
            // 因此,将搜索范围缩小到当前行的下一行 
            }else{
                x++;
            }
        }
        // 如果遍历完所有可能的搜索范围都没有找到目标值,则返回false 
        return false;
      }

该算法的思想是通过选择合适的起始搜索点,并利用矩阵的行和列都是有序的这一特性,通过不断缩小搜索范围来高效地找到目标值或确定目标值不存在于矩阵中。

复杂度分析——Z查找

  • 时间复杂度:由于每次比较后,搜索范围都会缩小一行或一列,因此该算法的时间复杂度为O(m+n),其中m是矩阵的行数,n是矩阵的列数。这是因为算法最多会遍历矩阵的每一行和每一列各一次。
  • 空间复杂度:该算法的空间复杂度为O(1),因为它只使用了常数个变量来存储搜索过程中的状态(如当前行索引x、当前列索引y以及矩阵的行数m和列数n),而没有使用额外的数据结构来存储搜索过程中的中间结果。

okok,拜拜啦!做完啦

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/774058.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构 —— 最小生成树

数据结构 —— 最小生成树 什么是最小生成树Kruskal算法Prim算法 今天我们来看一下最小生成树&#xff1a; 我们之前学习的遍历算法并没有考虑权值&#xff0c;仅仅就是遍历结点&#xff1a; 今天的最小生成树要满足几个条件&#xff1a; 考虑权值所有结点联通权值之和最小无环…

JavaWeb开发之环境准备-大合集

本文博客地址 JavaWeb开发 || 环境准备 1. 前言2. JDK8安装2.1 下载地址2.2 安装配置图示2.2.1 JDK安装2.2.2 配置系统环境变量 3. Maven安装3.1 Maven下载3.2 Maven解压及系统变量配置 4. Tomcat安装4.1 Tomcat下载4.2 Tomcat解压及系统变量配置 5. Redis安装5.1 Redis下载5.…

六西格玛绿带培训如何告别“走过场”?落地生根

近年来&#xff0c;六西格玛绿带培训已经成为了众多企业提升管理水平和员工技能的重要途径。然而&#xff0c;不少企业在实施六西格玛绿带培训时&#xff0c;往往陷入形式主义的泥潭&#xff0c;导致培训效果大打折扣。那么&#xff0c;如何避免六西格玛绿带培训变成“走过场”…

Java排序算法过程详解

标题 冒泡排序选择排序插入排序(抓牌)希尔排序归并排序 ​排序算法大体可分为两种&#xff1a; 1、比较排序&#xff0c;时间复杂度O(nlogn) ~ O(n^2)&#xff0c;主要有&#xff1a;冒泡排序&#xff0c;选择排序&#xff0c;插入排序&#xff0c;归并排序&#xff0c;堆排序&…

allure如何记录操作步骤,操作步骤不写在测试用例中,同样可以体现在allure报告,如何实现

嗨&#xff0c;我是兰若&#xff0c;今天写完用例&#xff0c;在运行用例并且生成报告的时候&#xff0c;发现报告里面没有具体的操作步骤&#xff0c;这可不行&#xff0c;如果没有具体的操作步骤的话&#xff0c;用例运行失败了&#xff0c;要怎么知道问题是出现在哪一个步骤…

【分布式数据仓库Hive】Hive的安装配置及测试

目录 一、数据库MySQL安装 1. 检查操作系统是否有MySQL安装残留 2. 删除残留的MySQL安装&#xff08;使用yum&#xff09; 3. 安装MySQL依赖包、客户端和服务器 4. MySQL登录账户root设置密码 5. 启动MySQL服务 6. 登录MySQL&#xff0c;进入数据库操作提示符 7. 授权H…

中级职称如何查询真假呢?

关于中级职称如何查询真假&#xff0c;大家都会有疑问&#xff0c;办到职称的人员肯定是想查一查手里的证书&#xff0c;那么没有证书的人员也想了解一下&#xff0c;今天甘建二告诉大家几个通俗的职称查询方式&#xff1a; 1.电话查询&#xff08;以前办理职称是这种查询方式…

大模型备案关注点最详细说明【附流程+附件】

国家网信办已经公布的通过大模型备案的有117家&#xff0c;部分已面向全社会开放服务。加上业内一些渠道透漏的消息&#xff0c;目前已有超过140个大模型获得备案。相对于算法备案&#xff0c;大模型备案名额显然更难拿到&#xff0c;很多企业在申请大模型备案的时候是一头雾水…

qiankun实现子应用tab页签切换缓存页面

实现背景 项目中是使用的jeecg-boot低代码构建的前端开发环境&#xff0c;由于后期各个模块代码越来越多&#xff0c;打包慢&#xff0c;分支管理麻烦&#xff0c;领导要求使用微前端&#xff0c;每个模块拆分为子应用。 拆分子应用 由于jeecg里面自带qiankun&#xff0c;所…

1.1.2数据结构的三要素

一.数据结构的三要素 数据结构这门课着重关注的是数据元素之间的关系&#xff0c;和对这些数据元素的操作&#xff0c;而不关心具体的数据项内容 。 1.逻辑结构 &#xff08;1&#xff09;集合结构 &#xff08;2&#xff09;线性结构 数据元素之间是一对一的关系。除了第一个…

虚幻引擎 快速的色度抠图 Chroma Key 算法

快就完了 ColorTolerance_PxRange为容差&#xff0c;这里是0-255的输入&#xff0c;也就是px单位&#xff0c;直接用0-1可以更快 Key为目标颜色

[数据集][目标检测]护目镜检测数据集VOC+YOLO格式888张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;888 标注数量(xml文件个数)&#xff1a;888 标注数量(txt文件个数)&#xff1a;888 标注类别…

【微信小程序开发实战项目】——花店微信小程序实战项目(4)

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;开发者-曼亿点 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 曼亿点 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a…

10种有效提高电子设备可靠性的PCB散热技术

在现代电子领域&#xff0c;随着器件尺寸的不断缩小和性能的不断提高&#xff0c;热管理问题日益凸显&#xff0c;不容忽视。电子设备在运行过程中产生的热量&#xff0c;如果处理不当&#xff0c;散发不了&#xff0c;就会像潜移默化的威胁一样&#xff0c;悄无声息地危及设备…

Desktop docker 部署 WordPress

Desktop Docker 部署 WordPress 之前都是在Linux里面玩的,今天看到别人在windwos下安装docker,一时兴起装了一个试试,效果一般,很吃硬盘空间和内存。 首先在docker官方下载桌面版,安装下一步一直到完成。 安装完docker会自动加入到环境变量,而且docker-compose也会一并安…

SPLL单相软件锁相环相关源代码理解-SOGI及PI系数计算

最近在学习TI的TIDA-010062&#xff08;DSP型号用的是TMS320F280049C&#xff09;&#xff0c;也就是1kW、80 Plus Titanium、GaN CCM 图腾柱无桥 PFC 和半桥 LLC&#xff08;具有 LFU&#xff09;参考设计。在整个框图中看到SPLL_1ph_SOGI的模块&#xff08;实验4&#xff1a;…

软件测试面试题集(含答案)

软件测试面试题集一、Bug基本要素 缺陷ID&#xff0c;状态&#xff0c;类型&#xff0c;所属项目&#xff0c;所属模块&#xff0c;缺陷提交时间&#xff0c;缺陷提交人&#xff08;检测者&#xff09;&#xff0c;严重程度&#xff0c;优先级别&#xff0c;缺陷描述信息&#…

【TS】TypeScript 联合类型详解:解锁更灵活的类型系统

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 TypeScript 联合类型详解&#xff1a;解锁更灵活的类型系统一、联合类型的定义二…

一站式采购!麒麟信安CentOS安全加固套件上架华为云云商店

近日&#xff0c;麒麟信安CentOS安全加固套件正式上架华为云云商店&#xff0c;用户可登录华为云官网搜索“CentOS安全加固”直接采购&#xff0c;一站式获取所需资源。 麒麟信安CentOS安全加固套件已上架华为云 https://marketplace.huaweicloud.com/contents/9fe76553-8d87-…

后端部署Jar包 | 启动失败系列问题(图解-BuiId,Maven)

目录 项目的构建 打包前的准备 合理配置pox.xml文件 Build 打包方式 Maven打包方式 Jar包部署 测试后端接口 项目的构建 我的项目是SpringBoot2脚手架 先准备一个相对于的数据库依赖 数据库的任意库 Yaml配置后 才能正常在IDEA中跑起来 打包前的准备 合理配置pox.xm…