给定一个整数数组nums和一个整数目标值target,请你在该数组中找出和为目标值target的那两个整数,并返回它们的数组下标。如何用java代码实现
时间: 2023-05-27 20:06:56 浏览: 80
两数之和 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个
```
public int[] twoSum(int[] nums, int target) {
Map<Integer, Integer> map = new HashMap<>();
for (int i = 0; i < nums.length; i++) {
int complement = target - nums[i];
if (map.containsKey(complement)) {
return new int[] { map.get(complement), i };
}
map.put(nums[i], i);
}
throw new IllegalArgumentException("No two sum solution");
}
```
这里使用了哈希表来记录每个数字的下标。遍历数组时,计算当前数字与目标值的差值,然后在哈希表中查找是否存在这个差值,如果存在,说明找到了两个数,直接返回它们的下标;如果不存在,将当前数字与其下标存入哈希表中。如果遍历完整个数组仍然没有找到答案,说明不存在这样的两个数,抛出异常。
阅读全文