Leetcode 30天高效刷数据结构和算法 Day1 两数之和 —— 无序数组


两数之和 —— 无序数组
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。
你可以按任意顺序返回答案。
示例 1:
输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。
示例 2:
输入:nums = [3,2,4], target = 6
输出:[1,2]
示例 3:
输入:nums = [3,3], target = 6
输出:[0,1]
两数之和问题解法
1. 暴力解法
代码
public static int[] twoSum(int[] nums, int target) {for(int i=1;i<nums.length;i++){for (int j=0; j<i; j++) {if(nums[i]+nums[j]==target){return new int[]{j,i};}}}return new int[0];
}
时间复杂度
O(n²)
2. 优化
优化思路
如果要同时判断符合条件的i和j是否存在数组中,则必定需要使用双层循环,时间复杂度为O(n²)+。
因此我们可以考虑将另一个参数表示为target-x(x为第一个参数)。
为了判断是否存在,考虑使用哈希表,来存储数组元素:元素下标,Map就是典型的空间换时间。
此时我们最多遍历一次数组,因此优化后的时间复杂度为O(n)
代码
public static int[] twoSum1(int[] nums, int target) {Map<Integer,Integer> map = new HashMap<>();for (int i = 0; i < nums.length; i++) {if(map.containsKey(target-nums[i])){return new int[]{map.get(target-nums[i]),i};}map.put(nums[i],i);}return new int[]{0};
}
时间复杂度
O(n)
相关文章:
Leetcode 30天高效刷数据结构和算法 Day1 两数之和 —— 无序数组
两数之和 —— 无序数组 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现…...
Hair Tool for Blender3D
CGer.com - Hair Tool for Blender3D - CGer资源网 Hair Tool 1.5 for Blender3D 链接: https://pan.baidu.com/s/1kVABn6n 密码: gwprHair Tool 1.65-1.8 for Blender链接: https://pan.baidu.com/s/1A7cW_Ms2baGQ2M0iE1dQhQ 密码: 81bqHair Tool for Blender 1.9.2链接: http…...
【最详解】如何进行点云的凹凸缺陷检测(opene3D)(完成度80%)
文章目录 前言实现思路想法1想法2想法3 补充实现想法1想法2代码 想法3代码 总结 前言 读前须知: 首先我们得确保你已经完全知晓相关的基本的数学知识,其中包括用最小二乘法拟合曲二次曲面,以及曲面的曲率详细求解。若还是没弄清楚࿰…...
海外云手机——平台引流的重要媒介
随着互联网的飞速发展,跨境电商、短视频引流以及游戏行业等领域正经历着迅猛的更新换代。在这个信息爆炸的时代,流量成为至关重要的资源,而其中引流环节更是关乎业务成功的关键。海外云手机崭露头角,成为这一传播过程中的重要媒介…...
数据库-计算机三级学习记录-4DBAS功能概要设计
DBAS功能概要设计 参照b站【计算机三级数据库技术】 DBAS功能设计包括应用软件中的数据库事务设计和应用程序设计。 功能设计过程一般被划分为总体设计、概要设计和详细设计。而具体到数据库事务设计部分,又可分成事务概要设计和事务详细设计。完成系统设计工作之后…...
JVM-虚拟机栈
虚拟机栈 Java虚拟机栈(Java Virtual Machine Stack)采用栈的数据结构来管理方法调用中的基本数据,先进后出(First In Last Out),每一个方法的调用使用一个栈帧(Stack Frame)来保存。 接下来以…...
linux系统上tomcat简介以及安装tomcat
tomcat简介以及安装 Tomcat简介安装环境安装jdk安装tomcat浏览器访问 Tomcat简介 Tomcat是一个开源的Web服务器和servlet容器,由Apache软件基金会开发和维护。它是一种流行的Java Web应用服务器,用于运行Java编写的Web应用程序。 Tomcat提供了一个轻量级…...
树莓派的pip安装时候添加清华源
每次都要去找镜像网址,太麻烦了,通过改配置可以一次性解决。 首先创建一个.pip 目录 mkdir ~/.pip意味着在当前目录下创建.pip文件,不过这个是隐藏文件,一般情况下是关闭隐藏文件的可视的,于是我绕了点弯弯。 编辑…...
共享网盘系统PHP源码
新V5.0版本,支持上传视频、支持视频播放、支持共享,也可以自己用。 可以自动生成视频外链,下载地址,播放器代码,html代码,ubb代码等等。 使用方法: 源码上传到服务器,打开网站根据…...
unity-ios-解决内购商品在Appstore上面已配置,但在手机测试时却无法显示的问题
自己这几天用 unity 2021 xcode 14.2 开发ios内购,appstore上面内购商品都已经配置好了,但是在手机里就是不显示,最后才发现必需得满足以下条件才行: 1. Appstore后台 -> 内购商品 -> 商品状态必需为『准备提交』以上状态…...
flask的基本使用 token插件(二)
一、安装flask-jwt-extended 安装flask-jwt-extend得时候 会自动安装一个pyjwt得库。pyjwt可以直接使用来生成JWT和验证。但是在flask中,可以通过Flask-JWT-Extended来实现JWT能,因为他封装了使用方式,以及一些属性和装饰器,用起…...
云计算、Docker、K8S问题
1 云计算 云计算作为一种新兴技术,已经在现代社会中得到了广泛应用。它以其高效、灵活和可扩展特性,成为了许多企业和组织在数据处理和存储方面的首选方案。 1.1 什么是云计算?它有哪些特点? 云计算是一种通过网络提供计算资源…...
【Iceberg学习二】Branch和Tag在Iceberg中的应用
Iceberg 表元数据保持一个快照日志,记录了对表所做的更改。快照在 Iceberg 中至关重要,因为它们是读者隔离和时间旅行查询的基础。为了控制元数据大小和存储成本,Iceberg 提供了快照生命周期管理程序,如 expire_snapshots…...
在 Blazor WASM 中手撸一个.NET MD5类
最近.net8 blazor auto大火, 我也玩了一下,发现ssr能用的代码 MD5 类在wasm是没法用的. 于是搜索了一下互联网,找到了一份代码,分享给大家. 我找到的帖子作者原话: 代码不是我的,但我确实稍微修改了它以使其与 System.Security.Cryptography.MD5 类更加一致。 pub…...
MFC实现遍历系统进程
今天我们来枚举系统中的进程和结束系统中进程。 认识几个API 1)CreateToolhelp32Snapshot 用于创建系统快照 HANDLE WINAPI CreateToolhelp32Snapshot( __in DWORD dwFlags, //指定快照中包含的系统内容__in DWORD th32P…...
【C语言】深入理解指针
目录 1.字符指针 2.指针数组 3.数组指针 4.数组传参与指针传参 一维数组传参 二维数组传参 一级指针传参 二级指针传参 5.函数指针 6.函数指针数组 7.指向函数指针数组的指针(了解即可) 8.回调函数 回调函数的应用:库函数qsort …...
Excel——有效性、二级菜单联动
一、录入规范数据 1.手动输入序列录入有效性信息 选择需要录入有效性的所有单元格 选择【数据】——【有效性】——【有效性】 在【允许】输入的值之间选择【序列】 在【序列】输入框中输入想要选择的值,中间用逗号(必须是英文逗号)隔开 。…...
计算机网络总结
1. 网络分层 网络上进行协议分层的好处 ①分层之后层次之间的耦合程度比较低,上层协议不必了解下层的细节,下层也不必了解上层的细节; ②方便的对某一层的协议进行替换; 真实网络的协议分层 OSI 七层网络模型(教科书&…...
初识文件包含漏洞
目录 什么是文件包含漏洞? 文件包含的环境要求 常见的文件包含函数 PHP伪协议 file://协议 php://协议 php://filter php://input zip://、bzip2://、zlib://协议 zip:// bzip2:// zlib:// data://协议 文件包含漏洞演示 案例1:php://inp…...
AR特效自研AI算法技术解决方案
在当今这个高速发展的数字化时代,增强现实(AR)技术已经成为企业创新和市场竞争的重要手段。美摄科技凭借对AI技术的深厚积累,为企业提供了一套创新的AR特效自研AI算法技术解决方案,旨在满足企业在AR领域的多元化需求。…...
手机拍照鬼影是算法背锅?聊聊Sensor DOL-HDR技术如何从源头减少融合断层
手机HDR成像鬼影溯源:从DOL-HDR硬件机制到ISP融合调优实战 在手机摄影技术快速迭代的今天,高动态范围(HDR)成像已成为旗舰机型的标配功能。然而,当算法工程师面对合成图像中的鬼影伪影和亮度断层时,往往陷入…...
bsnes性能优化技巧:CPU、SA1和SuperFX超频配置完全手册
bsnes性能优化技巧:CPU、SA1和SuperFX超频配置完全手册 【免费下载链接】bsnes bsnes is a Super Nintendo (SNES) emulator focused on performance, features, and ease of use. 项目地址: https://gitcode.com/gh_mirrors/bs/bsnes bsnes是一款专注于性能…...
无代码构建AI智能体:Databerry实战指南与RAG应用解析
1. 项目概述:告别代码,用Databerry构建专属AI智能体如果你对AI聊天机器人感兴趣,但又觉得从零开始写代码、调模型、处理向量数据库这些事太麻烦,那Databerry这个项目可能就是为你准备的。简单来说,Databerry是一个“无…...
马上开课!因果推断与机器学习训练营,10天带你写出能“下结论”的论文!
为什么有些人服药后康复,而另一些人却毫无改善?为什么大学学位能改变收入水平?这些如果……会怎样的问题,其实都属于因果推断的范畴。在医疗研究中,许多问题都涉及因果概念,因此因果推断在健康研究领域越来…...
开源爬虫框架OpenClaw深度集成Bitrix24:企业级数据自动化采集实战
1. 项目概述:当开源爬虫框架遇上企业级CRM如果你正在寻找一个能够与Bitrix24深度集成、稳定可靠且高度可定制的数据采集方案,那么rsvbitrix/openclaw-bitrix24这个开源项目绝对值得你花时间深入研究。简单来说,这是一个基于Python的爬虫框架&…...
AI驱动全栈开发:RapidFireAI如何实现端到端自动化与效率革命
1. 项目概述:当AI遇上“速射”,一个全栈开发者的效率革命最近在GitHub上闲逛,发现一个名字很酷的项目——RapidFireAI/rapidfireai。光看名字,“RapidFire”(速射)加上“AI”,就让人感觉这玩意儿…...
我是怎么用 AI 把自己的知识“榨”出来的:Skill的再实践
在某些 AI 群里潜水久了,我养成了一个坏毛病。 每次看到有人发问题,我都会在心里默默评价:这问题问得太幼稚了、这个思路走歪了、这个工具根本不该这么用、怎么会问出这种问题…… 但如果有人反过来问我:“那你说,正确…...
黎巴嫩五大核心港口:贝鲁特港、的黎波里港等
黎巴嫩三大核心港口——贝鲁特港、的黎波里港与赛达港,分工明确、互补发力,承担全国进出口货运重任,是中东航运与区域贸易的关键枢纽。一、贝鲁特港(LBBEY):全国第一大港、中东航运枢纽贝鲁特港位于贝鲁特北…...
【编号948】甘肃省-1990-2025年全国30m土地利用数据集
今天分享的是 甘肃省-1990-2025年全国30m土地利用数据集 数据概况 甘肃省-1990-2025年全国30m土地利用数据集。坐标系。TIF数据.详情图请看上面图片。请自行斟酌使用。 其他闲聊概况 甘肃省地处黄土高原、内蒙古高原与青藏高原交汇地带,黄河上游,地貌…...
2026年跨行业通吃的经管类黄金证书推荐
在数字经济纵深发展与人工智能技术广泛渗透的2026年,经济管理领域的人才需求范式发生了结构性转变。传统的单一专业技能边界日益模糊,企业对具备数据驱动决策、跨领域协同与敏捷管理能力的复合型人才需求迫切。在此背景下,系统性获取权威职业…...
