问题描述:给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。 你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同一个元素进行求和。
时间: 2023-10-20 21:16:14 浏览: 116
这是一个典型的求两数之和的问题,可以使用哈希表来解决。
具体思路如下:
1. 创建一个哈希表,用来存储每个数字对应的下标;
2. 遍历数组,对于每个数字,查找哈希表中是否存在 target - nums[i] 的键值,如果存在,则找到了两个数的和为 target;
3. 如果哈希表中不存在,则将当前数字及其下标存入哈希表中。
下面是具体的实现代码:
```python
def twoSum(nums, target):
hash_table = {}
for i, num in enumerate(nums):
complement = target - num
if complement in hash_table:
return [hash_table[complement], i]
hash_table[num] = i
return None
```
其中,enumerate 函数可以同时获取元素和下标,以便于在哈希表中存储数字对应的下标。
你可以按照下面的方式调用该函数,以验证其正确性:
```python
nums = [2, 7, 11, 15]
target = 9
print(twoSum(nums, target)) # 应该输出 [0, 1]
```
输出结果为 [0, 1],表示在数组中下标为 0 和下标为 1 的两个数的和为目标值 9。
相关问题
写代码:给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
以下是Python代码实现:
```python
def twoSum(nums, target):
hashmap = {}
for i, num in enumerate(nums):
if target - num in hashmap:
return [hashmap[target - num], i]
hashmap[num] = i
return []
```
这里使用了哈希表来优化查找的时间复杂度,算法的时间复杂度为 O(N),其中 N 是数组中元素的个数。
用C语言实现:给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。
好的,下面是用C语言实现的代码:
```c
int* twoSum(int* nums, int numsSize, int target, int* returnSize){
int i, j;
int* res = (int*)malloc(sizeof(int) * 2);
*returnSize = 2;
for(i = 0; i < numsSize - 1; i++){
for(j = i + 1; j < numsSize; j++){
if(nums[i] + nums[j] == target){
res[0] = i;
res[1] = j;
return res;
}
}
}
return NULL;
}
```
这段代码使用了双重循环,依次遍历数组中的每一个元素,找到其中两个元素的和等于目标值,返回它们的下标。
阅读全文