01.两数之和
# 01.两数之和
难度:简单
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
1
2
3
2
3
# 暴力法
# 思路
双循环破解
外层循环获取 nums[0] 到 nums[length-2]
的 i
索引值
内存循环获取 nums[1]到nums[length-1]
的 j
索引值
判断 nums[i] + nums[j] == target
则返回 [ i , j ]
# 代码
class Solution {
public int[] twoSum(int[] nums, int target) {
int[] arr = new int[2];
for(int i=0;i<nums.length;i++){
for(int j=(i+1);j<nums.length;j++){
if(nums[i]+nums[j] == target){
arr[0] = i;
arr[1] = j;
return arr;
}
}
}
throw new IllegalArgumentException("No two sum solution");
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 哈希法
# 思路
遍历 nums
通过判断每一次遍历的 key
是否满足 nums[i] - target
满足则返回结果 {map.get(nums[i]-target),i}
每次遍历都 map.put(nums[i], i)
# 代码
class Solution {
public int[] twoSum(int[] nums, int target) {
Map<Integer, Integer> map = new HashMap<>();
for (int i = 0; i < nums.length; i++) {
if (map.containsKey(nums[i] - target)) {
return new int[]{map.get(nums[i] - target), i};
}
map.put(nums[i], i);
}
throw new IllegalArgumentException("No two sum solution");
}
}
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
上次更新: 2021/01/05, 01:59:46