LeetCode/1. 两数之和

1. 两数之和

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。

示例 :

1
2
3
4
给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

来源:力扣(LeetCode)
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解:

本题一开始很容易进入一个误区,就是先将数组排序,然后通过双指针解题(我不会告诉你我一开始就是这么想的),最后发现返回的索引不正确。所以本题用了HashMap结构,Key为当前位置数值,Value为当前位置索引,遍历整个数组,先将temp = target - nums[i]计算出来,如果HashMap中已经存在temp的值,直接返回两者的索引即可,如果不存在,则将当前值存到HashMap中。

具体代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Solution {
public int[] twoSum(int[] nums, int target) {
Map<Integer, Integer> map = new HashMap<>();
int temp = 0;
for (int i = 0; i < nums.length; i++) {
temp = target - nums[i];
if (map.containsKey(temp)) {
return new int[]{map.get(temp), i};
}
map.put(nums[i], i);
}
return new int[]{};
}
}

Comments