给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标
时间: 2023-05-31 19:18:40 浏览: 160
### 回答1:
题目描述:
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。
解题思路:
可以使用哈希表来解决这个问题。遍历数组,将每个元素作为键,将其下标作为值存储在哈希表中。在遍历过程中,检查哈希表中是否存在目标值与当前元素之差,如果存在,则返回两个元素的下标。
代码实现:
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
unordered_map<int, int> hash;
for (int i = 0; i < nums.size(); i++) {
int complement = target - nums[i];
if (hash.count(complement)) {
return {hash[complement], i};
}
hash[nums[i]] = i;
}
return {};
}
};
### 回答2:
题目链接:https://leetcode-cn.com/problems/two-sum/
题目描述:给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。
思路分析:该问题可以用哈希表解决。通过哈希表可以极大地减少查找时间。具体做法:遍历数组nums,每遍历到一个元素,判断哈希表中是否存在与之配对的目标元素。如果存在,那么直接返回两个元素的下标即可;否则,将当前元素插入到哈希表中,继续遍历。注意,在遍历之前,需要先将所有元素插入到哈希表中,否则有可能出现元素被重复计算的情况。
代码实现:
class Solution:
def twoSum(self, nums: List[int], target: int) -> List[int]:
hash_dict = {}
for i in range(len(nums)):
if target - nums[i] in hash_dict:
return [i, hash_dict[target - nums[i]]]
hash_dict[nums[i]] = i
return []
### 回答3:
本题的题目是“两数之和”。
题目大意:
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。
思路分析:
这道题最简单的思路就是采用暴力枚举,即遍历每组数的和是否等于目标值,时间复杂度为 O(n²),空间复杂度为 O(1)。
但是,我们可以采用哈希表的方法,用空间换时间。将每个数组中的数和它的下标存储在哈希表中,然后在哈希表中查找 target - nums[i] 是否存在即可。
时间复杂度为 O(n),空间复杂度为 O(n)。
代码实现:
```
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");
}
```
通过上述方法,我们可以很快地解决这道LeetCode的题目。
阅读全文