给定一个整数数组
nums
和一个整数目标值target
,请你在该数组中找出 和为目标值target
的那 两个 整数,并返回它们的数组下标。
这里有两种思路解决,第一种暴力法,第二种使用Map集合
方法一
public int[] twoSun(int[] nums,int target){
for (int i = 0; i < nums.length; i++) {
for (int j = 0; j < nums.length; j++) {
if (nums[i]+nums[j]==target)return new int[]{i,j};
}
}
throw new IllegalArgumentException("No two sum solution");
}
方式二 先存后查
public int[] twoSun1(int[] nums,int target){
HashMap<Integer, Integer> map=new HashMap<>();
//添加到map
for (int i = 0; i < nums.length; i++) {
map.put(nums[i],i);
}
for (int i = 0; i < nums.length; i++) {
//判断是否包含相减后结果,并且不是同一个元素
if (map.containsKey(target-nums[i])&&map.get(target-nums[i])!=i){
return new int[]{i,map.get(target-nums[i])};
}
}
throw new IllegalArgumentException("No two sum solution");
}
边存边查
public int[] twoSun2(int[] nums,int target){
HashMap<Integer, Integer> map=new HashMap<>();
//添加到map
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);
}
throw new IllegalArgumentException("No two sum solution");
}
两种方法,要么不浪费空间牺牲速度,要么不浪费速度牺牲时间。