力扣 0001.两数之和
目录
1.两数之和
问题
- 给定一个整数数组
nums
和一个整数目标值target
,请你在该数组中找出和为目标值target
的那两个整数,并返回它们的数组下标。
信息
-
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。
-
你可以按任意顺序返回答案。
示例 1:
|
|
示例 2:
|
|
示例 3:
|
|
法一:暴力解法
|
|
-
时间复杂度: O(N2),其中 N是数组中的元素数量。对于每一个元素
x
,我们可以 O(1) 地寻找target - x
。两个循环,所以是O(N2)。 -
空间复杂度: O(1)
-
简单粗暴,2遍for循环逐个遍历判断。
法二:哈希表(官方答案)
|
|
-
时间复杂度: O(N),其中 N是数组中的元素数量。对于每一个元素
x
,我们可以 O(1) 地寻找target - x
。 -
空间复杂度: O(N),其中 N是数组中的元素数量。主要为哈希表的开销。
-
一遍for循环搞定,将数字存在哈希表的键值对中,并判断
target-nums[i]
的结果在哈希表键值对中是否存在,是则说明找到匹配数字。 -
我们遍历到数字a时,用target减去a,就会得到b,若b存在于哈希表中,我们就可以直接返回结果了。若b不存在,那么我们需要将a存入哈希表,好让后续遍历的数字使用。