力扣第一题
给定一个整数数组 nums 和一个整数目标值 target,
请你在该数组中找出 和为目标值 target 的那 两个 整数,
并返回它们的数组下标。你可以假设每种输入只会对应一个答案。
但是,数组中同一个元素在答案里不能重复出现。
有两种实现方式
public static void main(String[] args) {
int[] nums = {7,2,11,15};
int target = 13;
System.out.println(Arrays.toString(twoSum2(nums,target)));
}
//一种方式,O(n^2)
public static int[] twoSum1(int[] nums, int target) {
for(int i = 0; i < nums.length; i ++){
for(int j = i + 1; j < nums.length; j ++){
if(nums[i] + nums[j] == target){
return new int[]{i,j};
}
}
}
return null;
}
//7,2,11,15 13 O(n)
public static int[] twoSum2(int[] nums, int target) {
//map的key是数组里的元素,map的value是下标
Map<Integer,Integer> map = new HashMap<>();
for(int i = 0; i < nums.length; i ++){
if(map.containsKey(target - nums[i])){
return new int[]{map.get(target - nums[i]),i};
}
map.put(nums[i], i);
}
return null;
}