1. 两数之和
题目:
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
解法:
哈希表,复杂度为O(n)
import java.util.*;
public class L1 {
public static void main(String[] args){
int target = 6;
// int[] nums = new int[] {2,7,11,15};
int[] nums = new int[] {3,2,4};
int[] indexs = new int[2];
AyList AyListRun = new AyList();
indexs = AyListRun.twoSum(nums, target);
System.out.println(Arrays.toString(indexs)) ;
HaMap HaMapRun = new HaMap();
indexs = HaMapRun.twoSum(nums,target);
System.out.println(Arrays.toString(indexs)) ;
}
}
//200ms 数组
class AyList {
public int[] twoSum(int[] nums, int target) {
ArrayList<Integer> List = new ArrayList<Integer>();
for (int i = 0; i<nums.length; i++){
if(List.contains(target - nums[i])) {
return new int[]{List.indexOf(target-nums[i]),i};
}
List.add(nums[i]);
}
return new int[0];
}
}
// 2ms 哈希表
class HaMap {
public int[] twoSum(int[] nums, int target) {
HashMap<Integer,Integer> map = new HashMap<Integer,Integer>();
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 new int[0];
}
}