用java写给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
时间: 2023-08-14 20:14:16 浏览: 98
好的,这是一道经典的算法题,可以使用哈希表(HashMap)来解决。
具体思路是:遍历数组中的每一个数,用target减去该数得到另一个数字,然后判断这个数字是否在哈希表中出现过。如果出现过,就说明找到了这两个数,返回它们的下标即可。如果没出现过,就把当前数字和它的下标存入哈希表中,等待下一次查找。
Java代码如下:
```java
public int[] twoSum(int[] nums, int target) {
HashMap<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);
}
return null;
}
```
其中,map存储的是每个数字对应的下标,时间复杂度为O(n)。
相关问题
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。java
在给定的整数数组中找出和为目标值的两个整数,并返回它们的数组下标,可以使用哈希表来解决这个问题。具体步骤如下:
1. 创建一个哈希表,用于存储数组中的元素及其对应的索引。
2. 遍历数组,对于每个元素 nums[i],计算目标值与当前元素的差值 diff = target - nums[i]。
3. 在哈希表中查找差值 diff,如果存在,则返回 diff 对应的索引和当前元素的索引 i。
4. 如果不存在差值 diff,则将当前元素及其索引加入哈希表中。
5. 如果遍历完整个数组仍未找到符合条件的两个数,则返回一个空数组。
以下是Java代码示例:
```java
import java.util.HashMap;
public class Solution {
public int[] twoSum(int[] nums, int target) {
HashMap<Integer, Integer> map = new HashMap<>();
for (int i = 0; i < nums.length; i++) {
int diff = target - nums[i];
if (map.containsKey(diff)) {
return new int[]{map.get(diff), i};
}
map.put(nums[i], i);
}
return new int;
}
}
```
请使用Java代码实现:给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
```java
import java.util.HashMap;
public class Solution {
public int[] twoSum(int[] nums, int target) {
// 创建一个HashMap,用于存储数组中的元素和它们的下标
HashMap<Integer, Integer> map = new HashMap<>();
// 遍历数组
for (int i = 0; i < nums.length; i++) {
// 计算目标值与当前元素的差值
int complement = target - nums[i];
// 在HashMap中查找差值是否存在
if (map.containsKey(complement)) {
// 如果存在,则返回差值的下标和当前元素的下标
return new int[] { map.get(complement), i };
}
// 如果差值不存在,则将当前元素和它的下标放入HashMap中
map.put(nums[i], i);
}
// 如果没找到,则返回空数组
return new int[] {};
}
}
```
以上代码使用了HashMap来存储数组中的元素和它们的下标,然后遍历数组,对于每个元素,计算目标值与它的差值,然后在HashMap中查找是否存在这个差值,如果存在,则返回差值的下标和当前元素的下标,否则将当前元素和它的下标放入HashMap中。如果遍历完整个数组都没有找到符合条件的两个元素,则返回空数组。
阅读全文
相关推荐














