leetCode-hot100-数组专题之子数组+二维数组

数组专题之子数组+二维数组

    • 子数组
      • 238.除自身以外数组的乘积
      • 560.和为K的子数组
    • 二维数组
      • 48.旋转图像

子数组

数组的子数组问题是算法中常见的一类问题,通常涉及到数组的连续元素。在解决这类问题时,常用的方法有前缀和、滑动窗口、双指针,分治法、动态规划等。下面分别对这几种方法进行简要说明:

  1. 滑动窗口(Sliding Window)
    • 适用于求解和为特定值、最大子数组和、最小子数组和、连续子数组的最大/最小值等问题。
    • 通过维护一个固定大小的窗口,在遍历数组的过程中不断移动窗口的位置,从而解决问题。
    • 常用于优化时间复杂度,避免重复计算。
  2. 双指针(Two Pointers)
    • 适用于求解有序数组中的问题,如两数之和、三数之和、有序数组中的区间和等。
    • 通常使用两个指针,一个从左向右移动,一个从右向左移动,或者一个指针固定,另一个指针移动。
    • 通过指针的移动,可以高效地找到满足条件的元素或子数组。
  3. 分治法(Divide and Conquer)
    • 适用于求解数组排序、数组划分等问题。
    • 将问题分解为若干个规模较小的相同问题,递归解决,最后合并结果。
    • 可以有效利用递归和分而治之的思想,解决复杂问题。
  4. 动态规划(Dynamic Programming)
    • 适用于求解最优解问题,如最长递增子序列、最长公共子序列、最长连续子数组等。
    • 通过将问题分解为更小的子问题,并存储子问题的解,避免重复计算。
    • 常用于优化时间复杂度,减少冗余计算。
  5. 前缀和(Dynamic Programming)
    • 计算数组的前缀和并存储。
    • 遍历前缀和数组,记录下所有满足条件的子数组。

在实际编程中,选择哪种方法取决于问题的具体性质和需求。滑动窗口和双指针通常用于优化时间复杂度,而分治法和动态规划则适用于更复杂的问题。在解决数组子数组问题时,可以根据问题的特点和需求,灵活运用这些方法。

238.除自身以外数组的乘积

思路:
本题需要得到数组中每个元素除本元素之外的所有元素的乘积的子数组,可以先计算出nums[i]左边元素的乘积,并计算出nums[i]右边元素的乘积,最后将两部分结果乘起来就是最后的结果,最后所有的结果保存到ans数组中,以下是一个栗子。
在这里插入图片描述

时间复杂度:
时间复杂度是 O(n),其中 n 是数组 nums 的长度。
代码实现:

class Solution {public int[] productExceptSelf(int[] nums) {int[] ans = new int[nums.length];ans[0] = 1;//将nums[i]左边的元素的乘积存在ans[i]里for(int i = 1;i < nums.length;i++){ans[i] = ans[i - 1] * nums[i - 1];}int rigth = 1;//将nums[i]右边的元素累乘到rigth中for(int i= nums.length - 1;i >= 0;i--){ans[i] *= rigth;rigth *= nums[i];}return ans;}
}

560.和为K的子数组

思路:
使用一个哈希表记录数组所有的前缀和和出现的次数,以前缀和为key,出现的次数为value,判断在哈希表中是否存在sum - k这个键值,若存在说明出现和为K的连续子数组,下面是一个图示:
在这里插入图片描述

在哈希表中存储到每一个元素的前缀和,,那么到j的前缀和和到i的前缀和相减,如果等于K,则说明该子数组和为K,所以可以得到 sum(0,j) - K = sum(0,i - 1),如果哈希表中有sum(0,j) - K这个键值,说明存在和为K的子数组,此时需要将对应的value值与ans相加。
时间复杂度:
时间复杂度为O(n),其中n是数组nums的长度。
代码实现:

class Solution {public int subarraySum(int[] nums, int k) {Map<Integer,Integer> record = new HashMap<>();int sum = 0;int ans = 0;//一定要初始化,初始化record是为了解决累加和等于k的情况。//如果不进行初始化操作,可能会导致错误的计算结果record.put(0,1);for(int i = 0;i < nums.length ; i++){sum += nums[i];if(record.containsKey(sum - k)){ans += record.get(sum - k);}record.put(sum, record.getOrDefault(sum, 0) + 1);}return ans;}
}

二维数组

对于二维数组的旋转问题,找到对应的规律就可以很快的解决。

48.旋转图像

思路:
对二维数组进行顺时针90°的旋转,可以拆分成先将数组按照主对角线进行翻转,然后再将得到的数组左右翻转,模拟的过程如图所示,所以只需要对数组进行两次循环先进行主对角线翻转,然后进行左右翻转即可,详细的讲解点击视频讲解-旋转图像。
在这里插入图片描述

时间复杂度:
用到了两层for循环,故时间复杂度为O(n^2)
代码实现:

class Solution {public void rotate(int[][] matrix) {int n = matrix.length;//按主对角线翻转for(int i = 0; i < n; i++){for(int j = 0; j < i; j++){int temp = matrix[i][j];matrix[i][j] = matrix[j][i];matrix[j][i] = temp;}}//左右翻转for(int i = 0; i < n; i++){for(int j = 0; j < n / 2; j++){int temp = matrix[i][j];matrix[i][j] = matrix[i][n - j - 1];matrix[i][n - j - 1] = temp;}}}
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

了解VS安全编译选项GS

缓冲区溢出攻击的基本原理就是溢出时覆盖了函数返回地址&#xff0c;之后就会去执行攻击者自己的函数&#xff1b; 针对缓冲区溢出时覆盖函数返回地址这一特征&#xff0c;微软在编译程序时使用了安全编译选项-GS&#xff1b; 目前版本的Visual Studio中默认启用了这个编译选项…

IAR9.30安装和注册相关

下载解压licpatcher64工具&#xff0c;把licpatcher64.exe拷贝到IAR的安装目录中双击运行。 示例IAR9.30.1默认安装如下如下&#xff0c;一共三个分别拷贝运行&#xff0c;不要遗漏。 C:\Program Files\IAR Systems\Embedded Workbench 9.1\arm\bin C:\Program Files\IAR Syst…

结构体(自定义类型)

1.结构体 结构体这种自定义的数据类型&#xff0c;让程序员可以自己创造适合的类型 结构是一些值的集合&#xff0c;这些值称为成员变量&#xff0c;结构的每个成员可以是不同类型的变量&#xff0c;可以是标量&#xff0c;数组&#xff0c;指针甚至是其他结构体 1.1.1 结构…

2024最新 Jenkins + Docker实战教程(七)- Jenkins实现远程传输和自动部署

&#x1f604; 19年之后由于某些原因断更了三年&#xff0c;23年重新扬帆起航&#xff0c;推出更多优质博文&#xff0c;希望大家多多支持&#xff5e; &#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Mi…

2024 五月份国内外CTF 散装re 部分wp

cr3CTF warmup 附件拖入ida main函数无法反汇编&#xff0c;仔细看&#xff0c;有花指令&#xff0c;jnz实际上必定跳转。有非常多处&#xff0c;可以写脚本patch程序去掉花指令&#xff0c;只要匹配指令&#xff0c;再获取跳转地址&#xff0c;nop掉中间的代码就行。但…

5.29_Java程序流程控制

CSDN 同C语言的流程同 1、补充&#xff1a; 1、switch使用时的注意事项 1、表达式只能是byte、short、int、char&#xff0c;JDK5开始支持枚举&#xff0c;JDK7开始支持String、不支持double、float、long switch里面是做分支匹配&#xff0c;也就是可以出现很多分支&am…

oracle12.1 rac 静默dbca教程(百分之百创建成功)

修改原响应文件 [oracleprimary1 database]$ cd response/ [oracleprimary1 response]$ ls dbca.rsp db_install.rsp netca.rsp [oracleprimary1 response]$ vi dbca.rsp 默认即可 数据库类型内存占比按需选择 运行静默创建实例脚本 [oracleprimary1 response]$ dbca -silen…

【传知代码】知识图谱推理-论文复现

文章目录 概述方法介绍核心逻辑实验条件数据集实验步骤实验结果 核心代码小结 本文涉及的源码可从知识图谱推理该文章下方附件获取 概述 本研究深入探讨了基于图神经网络&#xff08;GNN&#xff09;的知识图谱推理&#xff0c;特别聚焦于传播路径的优化与应用。在智能问答、推…

⌈ 传知代码 ⌋ YOLOv9最新最全代码复现

&#x1f49b;前情提要&#x1f49b; 本文是传知代码平台中的相关前沿知识与技术的分享~ 接下来我们即将进入一个全新的空间&#xff0c;对技术有一个全新的视角~ 本文所涉及所有资源均在传知代码平台可获取 以下的内容一定会让你对AI 赋能时代有一个颠覆性的认识哦&#x…

数据结构——二叉树的实现

文章目录 一、二叉树概念的回顾二、二叉树结构的定义三、二叉树的创建方法一、写个创建结点的函数然后手动链接起来创建结点的函数手动链接 方法二、通过前序遍历的数组的方式构建二叉树创建的函数声明创建函数的定义 四、 二叉树的遍历前序遍历中序遍历后序遍历层序遍历 五、二…

从零开始利用MATLAB进行FPGA设计(六)用ADC采集信号教程1

黑金的教程做的实在太拉闸了&#xff0c;于是自己摸索信号采集模块的使用方法。 ADC模块&#xff1a;AN9238 FPGA开发板&#xff1a;AX7020&#xff1b;Xilinx 公司的 Zynq7000 系列的芯片XC7Z020-2CLG400I&#xff0c;400引脚 FBGA 封装。 往期回顾&#xff1a; 从零开始利…

测试驱动编程(4)模拟消除依赖

文章目录 测试驱动编程(4)模拟消除依赖模拟框架Mockito什么要模拟名词解释Mockito常用注解Mockito常用静态方法Mockito测试流程三部曲基础用法可变返回结果验证verfily对象监视spy 示例实战升级版井字游戏需求一需求二需求三 总结 测试驱动编程(4)模拟消除依赖 模拟框架Mockit…

YOLOv8架构详解

&#x1f4cc;YOLOv8架构详解 YOLOv8 架构图YOLOv8 Backbone部分YOLOv8 Head部分Neck和Head结构 在视觉深度学习中&#xff0c;通常将模型分为 2~3 个组成部分&#xff1a;backbone、neck&#xff08;可选&#xff09; 和 head。 Backbone&#xff08;主干网络&#xff09;负责…

NTLite深度Windows系统镜像文件修改定制

计算机爱好者和技术宅的圈子里,NTLite是一个广受欢迎的名字,一款强大的Windows系统定制工具,允许用户对Windows安装镜像进行深度修改,从而打造出一个更加个性化、高效且精简的操作系统。无论是为了优化系统性能、移除不必要的组件,还是集成最新的更新和驱动,NTLite都能成…

java后端框架-MyBatis

一、概述 1、起源 MyBatis本是Apache下的开源项目&#xff0c;名为iBatis,2010年转投谷歌,从iBatis3.x开始更名为MyBatis 2、优点 (1)优秀的数据持久层框架&#xff08;对jdbc做了轻量级封装&#xff09; 3、特点 (1)对jdbc中接口进行封装的同时还提供了一些自己的类实现…

samba_ubuntu_share_vmbox_vmware

_____ Ubuntu 利用 samba 与 win 直接共享文件夹 _____ samba Samba - 维基百科&#xff0c;自由的百科全书 (wikipedia.org) 用于 win 和 unix 直接访问资源 samba 为选定的 unix 目录建立网络共享&#xff0c; 使得 win 用户可以像访问普通 win 下的文件夹那样来通过网络来…

npm : 无法加载文件 D:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚本

安装npm时出现如下提示&#xff1a; 出现这个错误信息&#xff0c;是系统禁止执行PowerShell的脚本。 出现的原因是&#xff0c;系统默认的执行策略是Restricted&#xff08;默认设置&#xff09;&#xff0c;限制执行&#xff0c;所以会出现如上提示。 解决方法&#xff1a;…

Linux服务器配置ssh证书登录

1、ssh证书登录介绍 Linux服务器ssh登录有密码登录和证书登录两种。如果使用密码登录&#xff0c;容易遭受密码泄露或者暴力破解&#xff0c;我们可以使用ssh证书登录并禁止使用密码登录&#xff0c;ssh证书登录通过公钥和私钥来完成整个连接过程&#xff0c;公钥保存在服务器…

高维数组到向量的转换:两种方法的深度解析

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、引言&#xff1a;高维数组的挑战与需求 二、方法一&#xff1a;使用NumPy库进行展平 示…

如何将md文件精确的转换成docx文件

如何将md文件转换成docx&#xff1f; 文章目录 如何将md文件转换成docx&#xff1f;一、如何将MD文件比较完美的转换成word呢&#xff1f;二、方法3 步骤1、下载一个可用的MarkDown编辑器2、下载Pandoc安装 三、来进行转化了 一、如何将MD文件比较完美的转换成word呢&#xff1…