给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。
你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
分析:
先理解题意,就是从一个数组里找出两个相加和为 target 的值,并返回数组的下标数组
题解一:
直接遍历,有相加为 target 且两个数下标不相等返回
class Solution {
public int[] twoSum(int[] nums, int target) {
int len = nums.length;
for(int i=0;i<len;i++)
for(int j=0;j<len;j++)
if(nums[i] + nums[j] == target && i!=j)
return new int[]{i,j};
return null;
}
}
题解二:
利用 Map(key,value) 的性质,将所有遍历过的数组值存为 key,所有数组下标存为 value,利用 containsKey 方法判断 Map 中是否含有该 key 值,如果有说明之前遍历过的数组值中存在和该数组值匹配(相加为 target)的值,则返回数组;否则继续设置当前 key 和 value ,进行下一轮遍历
class Solution {
public int[] twoSum(int[] nums, int target) {
Map<Integer,Integer> ans = new HashMap<>();
int len = nums.length;
for(int i=0;i<len;i++){
if(ans.containsKey(target - nums[i]))
return new int[]{ans.get(target - nums[i]),i};
ans.put(nums[i],i);
}
return null;
}
}