LeetCode每日一刷:两数之和

215 阅读2分钟

一起养成写作习惯!这是我参与「掘金日新计划 · 4 月更文挑战」的第5天,点击查看活动详情

1️⃣两数之和

  • 给定一个整数数组 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]

提示:

  • 2 <= nums.length <= 104
  • -109 <= nums[i] <= 109
  • -109 <= target <= 109
  • 只会存在一个有效答案

备注:本章所用语言:C++


2️⃣解题

🌱思路一

暴力枚举:

  • 利用两层for循环
  • 第一层for循环遍历数组中的每一个元素nums[i]
  • 第二层for循环对当前循环的元素nums[i],寻找后面的元素能否满足nums[i]+nums[j] == target的条件
  • 如果满足则返回下标{i,j},否则返回空数组{}

image.png

运行结果如下:

image.png

🌱思路二

哈希表解法

  • 题目要求是寻找数据关系,即在数组中寻找是否有元素x,y满足x+y==target
  • 所以我们自然就会想到,如果有一个容器存储着各个元素,然后给定元素nums[i],都可以在容器里查询,是否有元素满足target - nums[i]
  • 需要注意的是,题目要求返回的是下标
  • 所以我们需要一个存储下标对应的值的容器
  • 即哈希表: unordered_map 容器
  • unordered_map 容器C++ STL 标准库中的无序关联式容器之一

因此这道题的解法为:

  1. 将数组转化为哈希表map存储
  2. 然后遍历数组nums中的每一个元素x
  3. 寻找map中是否有匹配的元素y

image.png

运行结果:

image.png

3️⃣知识点

  • vector容器:动态大小数组的顺序容器
  • 哈希表:键值和值相互对应
  • C++标准库中的无序关联式容器:unordered_map

好了,每日一刷就到这里,如果你有更好的解法,欢迎到评论区一起探讨!!!