Leetcode Hot100之数组

1.最大子数组和

  • 题目描述
    给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
    子数组是数组中的一个连续部分。
  • 解题思路
    动态规划,遍历数组求取以当前元素为结尾的子数组的和,如果前面的和大于0,那么加上当前元素,如果前面的和小于0,则从当前元素重新开始计算
    时间复杂度:O(n) 空间复杂度:O(1)
  • 代码
    class Solution:def maxSubArray(self, nums: List[int]) -> int:n = len(nums)if n == 0:return Noneres = nums[0]prev = nums[0]for i in range(1, n):cur = nums[i]if prev > 0:cur += prevres = max(res, cur)prev = curreturn res
    

2. 合并区间

  • 题目描述
    以数组 intervals 表示若干个区间的集合,其中单个区间为 intervals[i] = [starti, endi] 。请你合并所有重叠的区间,并返回 一个不重叠的区间数组,该数组需恰好覆盖输入中的所有区间 。
  • 解题思路
    按照起始坐标排序,然后从前到后合并
  • 代码
    class Solution:def merge(self, intervals: List[List[int]]) -> List[List[int]]:n = len(intervals)if n < 2:return intervalsintervals = sorted(intervals, key=lambda x: x[0])res = []prev = intervals[0]for i in range(1, n):cur = intervals[i]if cur[0] <= prev[1]:prev[1] = max(cur[1], prev[1])else:res.append(prev)prev = curres.append(prev)return res
    

3. 轮转数组

  • 题目描述
    给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。
    示例 1:

      输入: nums = [1,2,3,4,5,6,7], k = 3输出: [5,6,7,1,2,3,4]解释:向右轮转 1 步: [7,1,2,3,4,5,6]向右轮转 2 步: [6,7,1,2,3,4,5]向右轮转 3 步: [5,6,7,1,2,3,4]
    
  • 解题思路
    先翻转整个数组,再分别翻转两个局部数组;
    注意k的大小可能会大于n,因此需要取余
    时间复杂度:O(n) 空间复杂度:O(1)

  • 代码

    class Solution:def rotate(self, nums: List[int], k: int) -> None:"""Do not return anything, modify nums in-place instead."""def reverse(nums, l, r):i = lj = rwhile i < j:nums[i], nums[j] = nums[j], nums[i]i += 1j -= 1n = len(nums)# 注意k有可能会大于n,因此需要对n取余数k = k % nreverse(nums, 0, n - 1)reverse(nums, 0, k - 1)reverse(nums, k, n - 1)
    

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

  • 题目描述
    给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。

    题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。

    请 不要使用除法,且在 O(n) 时间复杂度内完成此题。

  • 解题思路
    很容易可以想到,结果是 前缀乘积 * 后缀乘积,题目要求O(1)空间复杂度,且返回的结果res不算在空间复杂度内,那么就是用res保存前缀乘积,第二遍循环再依次乘以后缀乘积
    时间复杂度:O(n) 空间复杂度:O(1)

  • 代码

    class Solution:def productExceptSelf(self, nums: List[int]) -> List[int]:n = len(nums)res = [1] * nfor i in range(1, n):res[i] = res[i-1] * nums[i-1]post = 1for i in range(n - 2, -1, -1):post *= nums[i+1]res[i] *= postreturn res
    

5. 缺失的第一个正数

  • 题目描述
    给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数。
    请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。
  • 解题思路
    原地哈希:我们可以使用原地哈希的方法,因为我们要查找的元素的范围是[1, n], 数组的下标是[0, n-1],因此我们可以将元素i放到下标i-1的位置上,将所有正数都放到对应的位置之后,从头到尾遍历一遍数组,如果nums[i] != i + 1,说明i + 1就是缺失的第一个正数。
    时间复杂度:O(n) 空间复杂度:O(1)
  • 代码
    class Solution:def firstMissingPositive(self, nums) -> int:n = len(nums)i = 0# 不断将i的元素放到正确的位置while i < n:# 如果当前元素不在[1, n]的范围内,或者当前元素已经和目标位置的元素相等,那么直接跳过 if nums[i] <= 0 or nums[i] > n or nums[nums[i] - 1] == nums[i]:i += 1continuecur = nums[i]# 将nums[i]放到nums[i]-1的位置上nums[i], nums[cur-1] = nums[cur-1], nums[i]for i in range(n):if nums[i] != i + 1:return i + 1# 注意,如果[1, n]的所有元素都在数组内,缺失的第一个正数就是n+1,因此返回n+1return n + 1
    

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

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

相关文章

mysql 查询排名,包括并列排名和连续排名

在MySQL中&#xff0c;根据不同的需求&#xff0c;查询排名可以分为并列排名和连续排名两种情况。 以下是分别实现这两种排名的方法&#xff0c;考虑到兼容性&#xff0c;这里会提供适合较早版本MySQL&#xff08;即8.0之前版本&#xff09;的解决方案&#xff0c;同时也提及M…

influxdb内存存储改为硬盘存储

根据直接部署和docker配置寻找到配置文件&#xff0c;添加内容 [data]engine "tsi1"index-version "tsi1" 即可降低内存占用

Java对象List根据ID去重

Java对象List根据ID去重 一、前言1. 使用HashSet去重2. 使用Stream API去重3. 使用HashMap去重4. 使用TreeSet去重并保持顺序5. 使用LinkedHashMap确保插入顺序 一、前言 在Java中处理大数据时&#xff0c;常常会遇到需要去重的情况。假设我们有一个对象数组&#xff0c;其中对…

CloudCompare二次开发目录(C++长期更新版)

目录 一、环境配置二、功能开发 本文由CSDN点云侠原创&#xff0c;原文链接。如果你不是在点云侠的博客中看到该文章&#xff0c;那么此处便是不要脸的爬虫与GPT。 一、环境配置 WIN10系统下VS2019编译CloudCompare2.12.4CloudCompare与PCL数据格式的相互转换 二、功能开发 …

2024年电商618观察:这是最好的时代 这是最坏的时代

内容提要 目前阶段增长势头更强劲的是中小商家&#xff0c;而星图的核心数据还是10万多个品牌。 十九世纪&#xff0c;英国最伟大的作家狄更斯在他的小说《双城记》开篇中写道&#xff1a; 这是最好的时代&#xff0c;这是最坏的时代&#xff1b; 这是智慧的年代&#xff0c;…

游戏工作室的得力助手:探索高效代理IP软件的选择与应用

在数字化浪潮的推动下&#xff0c;游戏产业蓬勃发展&#xff0c;游戏工作室作为这一领域的重要参与者&#xff0c;其运营效率和稳定性成为了影响业务成功的关键因素。而在众多提升运营效率的工具中&#xff0c;代理IP软件凭借其独特的功能和优势&#xff0c;成为了游戏工作室不…

【LeetCode】每日一题:判断子序列

给定字符串 s 和 t &#xff0c;判断 s 是否为 t 的子序列。 字符串的一个子序列是原始字符串删除一些&#xff08;也可以不删除&#xff09;字符而不改变剩余字符相对位置形成的新字符串。&#xff08;例如&#xff0c;"ace"是"abcde"的一个子序列&#x…

Softhsm2和Cryptoki的基本操作

0. 测试模块是否正常工作 sudo pkcs11-tool --module /usr/lib/softhsm/libsofthsm2.so --show-info Cryptoki version 2.30 Manufacturer SoftHSM Library Implementation of PKCS11 (ver 2.2) 1. 列出所有槽(Slots) sudo pkcs11-tool --module /usr/lib/soft…

MyBatis(4)MyBatis 如何配置和使用

MyBatis 的配置和使用可以分为几个步骤进行详细解析。请注意&#xff0c;完整的源码分析是非常庞大的工作&#xff0c;这里会给出一个高层次的视图和关键代码演示。 1. MyBatis 配置 配置通常通过 mybatis-config.xml 配置文件进行&#xff0c;这个文件包括了对 MyBatis 行为…

台式扫描电镜工作距离越远观察区越大?

台式扫描电镜&#xff08;Scanning Electron Microscope, SEM&#xff09;是一种高分辨率的显微镜&#xff0c;它利用电子束扫描样品表面&#xff0c;通过样品与电子束相互作用产生的信号来形成图像。这种显微镜广泛应用于材料科学、生物学和医学等领域&#xff0c;以观察样品的…

提示词绕过大模型安全限制

大模型安全绕过策略 简介 本文使用简单的提示词&#xff0c;可以在所有场景中实现针对某开源模型的安全策略绕过。 glm-4-9b-chat 的安全措施还有待完善。 上一代的6b比这一代的9B&#xff0c;要安全&#xff1b;上一代的6B大模型这一招没有用。 正常对话 若在下述正常互动…

html +css 控制文本高度超出变成省略号

.overflow{height: 50px;display: -webkit-box; /* 使用Webkit的弹性盒子模型显示 */-webkit-line-clamp: 2; /* 限制在一个块元素显示的文本的行数 */-webkit-box-orient: vertical; /* 设置或检索伸缩盒对象的子元素的排列方式 */overflow: hidden; /* 隐藏超出容器的内容 */…

经纬恒润EAS.HSM:驱动硬件信息安全

概述 HSM&#xff08;Hardware Security Module&#xff09;硬件安全模块&#xff0c;是一种用于保护和管理强认证系统所使用的密钥&#xff0c;并同时提供相关密码学操作的计算机硬件设备。 HSM 在汽车信息安全中扮演着至关重要的角色。随着汽车智能化和网联化的快速发展&am…

ONLYOFFICE8.1版本震撼来袭

目录 软件简介 产品概述&#xff1a; 功能特点&#xff1a; 技术原理&#xff1a; 版本与部署&#xff1a; 8.1版本更新 全新的PDF编辑器 1.文本编辑 2.页面处理 &#xff08;添加、旋转、删除&#xff09; 3.插入和调整各种对象&#xff0c;例如表格、形状、文本框、…

MYSQL十、MYSQL的存储过程和触发器的基本认识

存储过程 存储过程&#xff1a;存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合。调用存储过程可以简化应用开发人员的很多工作&#xff0c;减少数据在数据库和应用服务器之间的传输&#xff0c;对于提高数据处理的效率是有好处的。 存储过程思想上很简单&#xff…

【学习笔记】数据结构(三)

栈和队列 文章目录 栈和队列3.1 栈 - Stack3.1.1 抽象数据类型栈的定义3.1.2 栈的表示和实现 3.2 栈的应用举例3.2.1 数制转换3.2.2 括号匹配的检验3.2.3 迷宫求解3.2.4 表达式求值 - 波兰、逆波兰3.2.5 反转一个字符串或者反转一个链表 3.3 栈与递归的实现3.4 队列 - Queue3.4…

Swift Combine — Scheduler(subscribe(on:)和receive(on:)的使用)

在 Swift 的 Combine 框架中&#xff0c;Scheduler 是一个重要的概念&#xff0c;用于控制任务的调度和执行。本文将详细介绍 Scheduler 的作用、常见的 Scheduler 类型以及如何使用 Scheduler 来管理任务的执行。 Scheduler 的定义 Scheduler 用于管理任务的调度和执行&…

Cell2Sentence:为LLM传输生物语言

像GPT这样的LLM在自然语言任务上表现出了令人印象深刻的性能。这里介绍一种新的方法&#xff0c;通过将基因表达数据表示为文本&#xff0c;让这些预训练的模型直接适应生物背景&#xff0c;特别是单细胞转录组学。具体来说&#xff0c;Cell2Sentence将每个细胞的基因表达谱转换…

AI学习指南机器学习篇-朴素贝叶斯模型应用与Python实践

AI学习指南机器学习篇-朴素贝叶斯模型应用与Python实践 在本篇博客中&#xff0c;我们将会介绍如何使用Python中的Scikit-learn库来实现朴素贝叶斯模型。朴素贝叶斯是一种常见的机器学习算法&#xff0c;它在文本分类、垃圾邮件检测等领域有着广泛的应用。通过本文的学习&…

小学数学蝴蝶模型详解

蝴蝶模型 1.蝴蝶模型仅存在于梯形中&#xff0c;是连接梯形两条对角线而形成的&#xff0c;如下图&#xff1a; 2.蝴蝶模型有几条公式 (1) (2) S△AODS△BOC 等等......