给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。 你可以按任意顺序返回答案。
时间: 2024-09-26 15:18:52 浏览: 23
两数之和 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个
这是一个经典的编程问题,通常称为“两数之和”(Two Sum)。给定一个已排序的整数数组 `nums` 和一个目标值 `target`,你需要找到数组中两个数,使得它们的和等于 `target`。解决这个问题的一种常见方法是使用哈希表(Hash Table),通过遍历数组,对于每个元素,检查哈希表中是否存在 `target - nums[i]` 这个值,如果存在,则找到了一对和为目标值的数,直接返回它们的下标;如果不存在,则将当前元素及其下标添加到哈希表中。这种方法的时间复杂度为 O(n),其中 n 为数组长度。
伪代码示例:
```python
def twoSum(nums, target):
hash_map = {}
for i, num in enumerate(nums):
complement = target - num
if complement in hash_map:
return [hash_map[complement], i]
hash_map[num] = i
return None # 如果找不到合适的一对数
```
阅读全文