当前位置: 首页 > news >正文

力扣 “两数之和” 最优解:哈希表 O (n) 时间复杂度实现详解

大家好,今天来讲解力扣经典入门题「两数之和」,分享如何用哈希表实现时间复杂度 O (n) 的高效解法。

一、题目回顾

给定整数数组nums和目标值target,找出数组中和为 target 的两个整数,返回它们的下标。

  • 假设输入只有一个答案
  • 不能使用同一个元素两次
二、暴力解法的问题

最直观的思路是双重循环遍历数组(时间 O (n²)),但数据量大时效率很低。

三、哈希表优化解法(我的代码)

利用哈希表存储 “数值 - 下标”,遍历数组时直接查找target - 当前数是否存在,实现一次遍历完成查找:

class Solution { public int[] twoSum(int[] nums, int target) { Map<Integer,Integer> map=new HashMap<>(); // 遍历数组 for(int i=0;i<nums.length;i++){ // 计算需要找的互补数 int complement = target - nums[i]; // 若互补数已在哈希表中,直接返回下标 if(map.containsKey(complement)){ return new int[]{map.get(complement),i}; } // 否则将当前数和下标存入哈希表 map.put(nums[i],i); } // 题目保证有解,这里仅为语法要求 return new int[0]; } }
四、代码逻辑拆解
  1. 初始化哈希表HashMap用来存已经遍历过的元素(键是数值,值是下标)。
  2. 遍历数组
    • 计算当前数的互补数complement = target - nums[i]
    • 检查哈希表中是否有这个互补数:
      • 有 → 直接返回 “互补数的下标” 和 “当前下标”。
      • 没有 → 把当前数和下标存入哈希表,继续遍历。
  3. 返回结果:题目保证有解,所以循环内一定会 return。
五、复杂度分析
  • 时间复杂度:O (n)(仅遍历一次数组,哈希表查找是 O (1))。
  • 空间复杂度:O (n)(最坏情况需要存储 n-1 个元素到哈希表)。

这个解法是「两数之和」的最优解之一,既简洁又高效,非常适合入门学习哈希表的应用~

http://www.jsqmd.com/news/106342/

相关文章:

  • 30-40 万新能源汽车 兼顾续航与智能的热门之选 - 速递信息
  • Skipping xxx as repository xxxx doesn‘t support architecture ‘i386‘
  • 基于WEB的高校计算机数据库课程知识图谱系统的设计与实现
  • TLS网络安全协议巩固知识基础题(2)
  • 网站建设公司怎么选?2025年网站设计制作公司推荐指南
  • 告别重复编码!10+顶级开发工具,引爆程序员效率革命
  • 聚焦家庭需求:20 万左右新能源 SUV 空间与安全优选车型
  • 基于SpringBoot + Vue的高校科研项目申报审批管理系统
  • 2026年河北省职业院校技能大赛中职组“网络建设与运维”竞赛样题
  • 基于SpringBoot + Vue的个性化学习系统
  • C语言5——常见关键字 define定义常量 表达式求值
  • 数学刷题总结
  • FlutterOpenHarmony底部导航栏组件开发
  • 2026年河北省职业院校技能大赛“信息技术应用创新”赛项(高职组)竞赛样题
  • FlutterOpenHarmony动画效果实现指南
  • 深度分析:AI智能体记忆是如何管理的?
  • 2025年中山可靠的无溶剂环氧涂料批发选哪家,石墨烯涂料/环氧玻璃钢/环氧酚醛/无溶剂环氧涂料/无溶剂环氧涂料设计推荐 - 品牌推荐师
  • 男生脱发:热门育发液哪个牌子效果最好?十大口碑防脱育发产品排行榜出炉 - 速递信息
  • 零样本克隆音色有多强?实测EmotiVoice语音复刻能力
  • kanass全面介绍(15) - Kanass如何有效集成sward文档
  • XL520无线接收芯片的简略说明
  • wechatapi-微信ipad协议新篇章-让账号更智能
  • 实用指南:智能网联汽车信息安全深度解析:从UN-R155与GB44495标准到OBD/UDS技术实践
  • sward全面介绍(14) - 集成企业微信,使用企业微信扫码登录sward
  • 【dz-943】基于单片机的电压表监测仪
  • 吴恩达深度学习课程四:计算机视觉 第二周:经典网络结构 (三)11卷积与Inception网络
  • Product Hunt 每日热榜 | 2025-12-17
  • Agent学习——通过ZENMUX来使用Xiaomi MiMo-V2-Flash(自用)
  • 苹果 iOS 开发真正复杂的不是写代码这方面,是证书、构建、上架
  • uniapp开发APP 内嵌外部 HTTPS 链接的实现方案