数组(四)-- LC[167] 两数之和-有序数组
1 两数之和
1.1 题目描述
题目链接:https://leetcode.cn/problems/two-sum/description/
1.2 求解思路
1. 暴力枚举
最容易想到的方法是枚举数组中的每一个数 x,寻找数组中是否存在 target - x
参考代码
class Solution(object):def twoSum(self, nums, target):n = len(nums)for i in range(n):for j in range(i+1, n):if nums[i]+nums[j]==target:return [i, j]
2. 哈希表
创建一个哈希表,对于每一个 x,我们首先查询哈希表中是否存在 target - x,然后将 x 插入到哈希表中,即可保证不会让 x 和自己匹配。
参考代码
class Solution:def twoSum(self, nums: List[int], target: int) -> List[int]:hash_dict = dict()for i, num in enumerate(nums):if target - num in hash_dict:return [hash_dict[target - num], i]else:hash_dict[num] = i
2 两数之和-输入有序数组
2.1 题目描述
题目链接:https://leetcode.cn/problems/corporate-flight-bookings/
2.2 思路分析
1. 二分查找
在数组中找到两个数,使得它们的和等于目标值,可以首先固定第一个数,然后寻找第二个数,第二个数等于目标值减去第一个数的差。利用数组的有序性质,可以通过二分查找的方法寻找第二个数。为了避免重复寻找,在寻找第二个数时,只在第一个数的右侧寻找。
参考代码
class Solution:def twoSum(self, numbers: List[int], target: int) -> List[int]:n = len(numbers)for i in range(n):low, high = i + 1, n - 1while low <= high:mid = (low + high) // 2if numbers[mid] == target - numbers[i]:return [i + 1, mid + 1]elif numbers[mid] > target - numbers[i]:high = mid - 1else:low = mid + 1return [-1, -1]
复杂度分析
- 时间复杂度:O(nlogn)O(nlogn)O(nlogn),其中 nnn 是数组的长度。需要遍历数组一次确定第一个数,时间复杂度是 O(n)O(n)O(n),寻找第二个数使用二分查找,时间复杂度是 O(logn)O(logn)O(logn),因此总时间复杂度是 O(nlogn)O(nlogn)O(nlogn)。
- 空间复杂度:O(1)O(1)O(1)。
2. 双指针
思路参考自————一张图告诉你 O(n) 的双指针解法的本质原理
为什么双指针往中间移动时,不会漏掉某些情况呢?
在这道题中,我们要寻找的是符合条件的一对下标 (i,j)(i, j)(i,j),它们需要满足的约束条件是:
- i、j 都是合法的下标,即 0≤i<n,0≤j<n0 \leq i < n, 0 \leq j < n0≤i<n,0≤j<n
- i < j(题目要求)
而我们希望从中找到满足 A[i]+A[j]==targetA[i] + A[j] == targetA[i]+A[j]==target 的下标 (i,j)。以 n=8 为例,这时候全部的搜索空间是:
由于 i、ji、ji、j 的约束条件的限制,搜索空间是白色的倒三角部分。可以看到,搜索空间的大小是 O(n2)O(n^2)O(n2) 数量级的。如果用暴力解法求解,一次只检查一个单元格,那么时间复杂度一定是 O(n2)O(n^2)O(n2)。要想得到 O(n)O(n)O(n) 的解法,我们就需要能够一次排除多个单元格。那么我们来看看,本题的双指针解法是如何削减搜索空间的:
一开始,我们检查右上方单元格 (0,7),即计算 A[0]+A[7]A[0] + A[7]A[0]+A[7],与 target 进行比较。如果不相等的话,则要么大于 target,要么小于 target。
假设此时 A[0]+A[7]A[0] + A[7]A[0]+A[7] 小于 target。这时候,我们应该去找和更大的两个数。由于 A[7] 已经是最大的数了,其他的数跟 A[0] 相加,和只会更小。也就是说 A[0]+A[6]、A[0]+A[5]、⋯、A[0]+A[1]A[0] + A[6] 、A[0] + A[5]、\cdots、A[0] + A[1]A[0]+A[6]、A[0]+A[5]、⋯、A[0]+A[1] 也都小于 target,这些都是不合要求的解,可以一次排除。这相当于 i=0i=0i=0 的情况全部被排除。对应用双指针解法的代码,就是 i++i++i++,对应于搜索空间,就是削减了一行的搜索空间,如下图所示。
排除掉了搜索空间中的一行之后,我们再看剩余的搜索空间,仍然是倒三角形状。我们检查右上方的单元格 (1,7)(1,7)(1,7),计算 A[1]+A[7]A[1] + A[7]A[1]+A[7] 与 target 进行比较。
假设此时 A[0]+A[7]A[0] + A[7]A[0]+A[7] 大于 target。这时候,我们应该去找 和更小的两个数。由于 A[1] 已经是当前搜索空间最小的数了,其他的数跟 A[7] 相加的话,和只会更大。也就是说 A[1]+A[7]、A[2]+A[7]、⋯、A[6]+A[7]A[1] + A[7] 、A[2] + A[7]、\cdots、A[6] + A[7]A[1]+A[7]、A[2]+A[7]、⋯、A[6]+A[7] 也都大于 target,这些都是不合要求的解,可以一次排除。这相当于 j=0j=0j=0 的情况全部被排除。对应用双指针解法的代码,就是 j++j++j++,对应于搜索空间,就是削减了一列的搜索空间,如下图所示。
可以看到,无论 A[i]+A[j]A[i] + A[j]A[i]+A[j] 的结果是大了还是小了,我们都可以排除掉一行或者一列的搜索空间。经过 nnn 步以后,就能排除所有的搜索空间,检查完所有的可能性。搜索空间的减小过程如下面动图所示:
参考代码
class Solution:def twoSum(self, numbers: List[int], target: int) -> List[int]:head, tail = 0, len(numbers)-1while head < tail:two_sum = numbers[head] + numbers[tail]if two_sum == target:return [head+1, tail+1]elif two_sum > target:tail -= 1else:head += 1
复杂度分析
- 时间复杂度:O(n)O(n)O(n),其中 nnn 是数组的长度。两个指针移动的总次数最多为 nnn 次。
- 空间复杂度:O(1)O(1)O(1)。
相关文章:
数组(四)-- LC[167] 两数之和-有序数组
1 两数之和 1.1 题目描述 题目链接:https://leetcode.cn/problems/two-sum/description/ 1.2 求解思路 1. 暴力枚举 最容易想到的方法是枚举数组中的每一个数 x,寻找数组中是否存在 target - x 参考代码 class Solution(object):def twoSum(self, n…...
Mac电脑,python+appium+安卓模拟器使用步骤
1、第一步,环境搭建,参考这位博主的文章,很齐全 https://blog.csdn.net/qq_44757414/article/details/128142859 我在最后一步安装appium-doctor的时候,提示权限不足,换成sudo appium-doctor即可 2、第二步࿰…...
Linux命令·find进阶
find是我们很常用的一个Linux命令,但是我们一般查找出来的并不仅仅是看看而已,还会有进一步的操作,这个时候exec的作用就显现出来了。 exec解释:-exec 参数后面跟的是command命令,它的终止是以;为结束标志的࿰…...
R语言ggplot2 | 用百分比格式表示数值
📋文章目录Percent() 函数介绍例子1,在向量中格式化百分比:例子2,格式化数据框列中的百分比:例子3,格式化多个数据框列中的百分比:如何使用percent()函数在绘图过程展示通常在绘图时,…...
【代码训练营】day53 | 1143.最长公共子序列 1035.不相交的线 53. 最大子序和
所用代码 java 最长公告子序列 LeetCode 1143 题目链接:最长公告子序列 LeetCode 1143 - 中等 思路 这个相等于上一题的不连续状态 dp[i] [j]:以[0, i-1]text1和以[0, j-1]text2 的最长公共子序列的长度为dp[i] [j]递推公式: 相同&#x…...
消息队列理解
为什么使用消息队列 使⽤消息队列主要是为了: 减少响应所需时间和削峰。降低系统耦合性(解耦/提升系统可扩展性)。 当我们不使⽤消息队列的时候,所有的⽤户的请求会直接落到服务器,然后通过数据库或者 缓存响应。假…...
【Linux内核一】在Linux系统下网口数据收发包的具体流向是什么?
在TCP/IP网络分层模型里,整个协议栈被分成了物理层、链路层、网络层,传输层和应用层。物理层对应的是网卡和网线,应用层对应的是我们常见的Nginx,FTP等等各种应用。Linux实现的是链路层、网络层和传输层这三层。 在Linux内核实现中…...
南京、西安集成电路企业和高校分布一览(附产业链主要厂商及高校名录)
前言 3月2日,国务院副总理刘鹤在北京调研集成电路企业发展,并主持召开座谈会。刘鹤指出,集成电路是现代化产业体系的核心枢纽,关系国家安全和中国式现代化进程。他表示,我国已形成较完整的集成电路产业链,也…...
后端Java随机比大小游戏实战讲解
## - 利用print打印输出提示用户 ## - 利用Scanner函数抓取数据 ## - 利用Math方法实现随机数 #### 1.首先用到的是print函数,对用户进行提醒进一步的操作 通过System.out.print();提示用户进行选择买大买小。 #### 2.然后利用Scanner函数,对用户输出…...
dolphinschedule使用shell任务结束状态研究
背景:配置的dolphin任务,使用的是shell,shell里包含了spark-submit 如下截图。 dolphin shell 介绍完毕,开始说明现象。 有天有人调整了集群的cdp配置,executor-cores max1 我之前这里写的是2,所以spark任…...
如何用postman实现接口自动化测试
postman使用 开发中经常用postman来测试接口,一个简单的注册接口用postman测试: 接口正常工作只是最基本的要求,经常要评估接口性能,进行压力测试。 postman进行简单压力测试 下面是压测数据源,支持json和csv两个格…...
AHRS(航姿参考系统)IMU(惯性测量单元)和INS的分析对比研究-2023-3-8
名称 AHRS俗称航姿参考系统 IMU 惯性测量单元 INS 惯性导航系统 英文 全称 (Attitude and Heading Reference System) (Inertial Measurement Unit) Inertial Navigation System) 组成 加速度计,磁…...
企业管理经典书籍推荐
几乎每一位成功的商业人士都有着良好的阅读习惯。并且他们阅读涉猎的范围也大多与企业管理和领导力有关。而关于企业管理经典书籍,我推荐你看以下这两本。一本是《经理人参阅:企业管理实务》,另一本是《经理人参阅:领导力提升》。…...
JVM系列——破坏双亲委派模型的场景和应用
上文提到过双亲委派模型并不是强制性的,而是Java设计者推荐的类加载器实现方式。 在Java的世界中大部分的类加载器都遵循这个模型,但也有例外的情况,直到Java 模块化出现为止,双亲委派模型出现过几次(3次?&…...
基于智能边缘和云计算的数字经济服务细粒度任务调度机制
数字经济被各国视为推动经济增长的必然选择,为经济高质量发展提供了新机遇、新路径。对于中国市场而言,云计算背后的强大基础是数字经济不可阻挡的发展趋势。在数字经济中,云作为基础设施成为构建数字经济金字塔的基础。为缓解数字经济服务器…...
ccc-pytorch-卷积神经网络实战(6)
文章目录一、CIFAR10 与 lenet5二、CIFAR10 与 ResNet一、CIFAR10 与 lenet5 第一步:准备数据集 lenet5.py import torch from torch.utils.data import DataLoader from torchvision import datasets from torchvision import transformsdef main():batchsz 128C…...
置信椭圆(误差椭圆)详解
文章目录Part.I 预备知识Chap.I 一些概念Chap.II 主成分分析Chap.III Matlab 函数 randnChap.IV Matlab 函数 pcaPart.II 置信椭圆的含义Chap.I 一个 Matlab 实例Sec.I 两个不相关变量的特征Sec.II 两个相关变量的特征Chap.II 变换阵 (解相关矩阵) 的求解ReferencePart.I 预备知…...
FreeSWITCH 智能呼叫流程设计
文章目录1. 智能呼叫流程2. 细节处理1. 呼叫字符串指定拨号计划2. 外呼的拨号计划3. 语音打断的支持1. 智能呼叫流程 用户与机器人对话通常都是以文本的形式进行,但是借助 ASR 和 TTS 技术,以语音电话为载体的智能呼叫系统成为可能。智能呼叫系统涉及到…...
什么是Restful风格
什么是RestFul风格? Restful就是一个资源定位及资源操作的风格。不是标准也不是协议,只是一种风格。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。 REST即Representational State Transfer的缩写࿰…...
sumifs的交叉 表的例子
比如这样,那么冰箱绿山店的栏位中,SUMIFS($D$3:$D$10,$B$3:$B$10,$F3,$C$3:$C$10,G$2)就是把求和范围,条件1设置为固定列的复合引用,条件2设置为固定行的复合引用即可。...
写论文没思路?这样梳理,新手也能快速理清逻辑
写论文最磨人的,从来不是熬夜写正文,而是明明定好了选题,却陷入“思路卡顿”的死循环——对着空白文档坐一下午,脑子里只有零散的碎片想法,不知道从哪切入、怎么展开,好不容易写下几句,又觉得逻…...
墨语灵犀GPU算力适配指南:A10/A100/V100显卡部署性能与显存占用实测
墨语灵犀GPU算力适配指南:A10/A100/V100显卡部署性能与显存占用实测 1. 引言:当古典美学遇见现代算力 想象一下,你正在处理一份重要的海外文献,或者需要将一段优美的中文诗歌翻译成英文。你希望翻译结果不仅准确,更要…...
从协议战争到SDN革命:华为数通技术演进中的那些关键抉择
从协议战争到SDN革命:华为数通技术演进中的关键抉择 在数据中心网络架构的演进历程中,技术路线的选择往往决定着企业未来十年的竞争力格局。当传统网络架构遭遇云计算时代的流量洪流,一场关于协议标准与技术范式的深刻变革悄然展开。这场变革…...
掌握串口数据可视化:用Serial Port Plotter实时监控硬件数据
掌握串口数据可视化:用Serial Port Plotter实时监控硬件数据 【免费下载链接】serial_port_plotter Displays real time data from serial port 项目地址: https://gitcode.com/gh_mirrors/se/serial_port_plotter 在嵌入式开发和硬件调试的世界里࿰…...
深入解析JLink与SWD接口:从引脚定义到实际调试应用
1. JLink调试器基础认知 第一次接触JLink时,我完全被那排密密麻麻的20针接口吓到了。这玩意儿真的比USB转串口工具复杂十倍不止!但用熟之后才发现,它其实是嵌入式开发的"瑞士军刀"。简单来说,JLink是SEGGER公司推出的专…...
中创新航发布2025年度业绩:总收入444亿元同比增长60% 盈利能力跨越式提升
3月27日,中创新航(03931.HK)发布2025年度业绩公告。公告显示,公司全年总收入444.00亿元人民币,同比增长约60.0%;年内利润20.95亿人民币,同比增长约148.4%,盈利能力实现跨越式提升&am…...
OFA-VE多模态推理实操手册:基于OFA-Large的语义对齐分析全流程
OFA-VE多模态推理实操手册:基于OFA-Large的语义对齐分析全流程 1. 引言:什么是视觉蕴含分析? 你有没有遇到过这样的情况:看到一张图片,然后有人用文字描述它,但你不太确定这个描述是否准确?或…...
嵌入式工程师必看:手把手教你排查PHY芯片挂载失败的6个硬件坑(附示波器实测图)
嵌入式工程师必看:手把手教你排查PHY芯片挂载失败的6个硬件坑(附示波器实测图) 调试一块新设计的PCB板时,最让人头疼的莫过于网口无法正常工作。作为一名嵌入式工程师,我经历过太多次PHY芯片无法被系统识别的窘境——那…...
抖音无水印下载工具:高效批量下载解决方案
抖音无水印下载工具:高效批量下载解决方案 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 在短视频内容创作与数字资产管理领域,抖音平台的海量内容为创作者提供了丰富的素材来源。然…...
Simulink低通滤波器实战:从随机信号生成到参数调优(附完整模型)
Simulink低通滤波器实战:从随机信号生成到参数调优(附完整模型) 在嵌入式系统和自动化工程领域,信号处理的质量往往直接决定整个系统的稳定性。想象一下,当你从传感器获取的实时数据充满噪声和毛刺时,如何确…...
