JS实现给定一个整数数组和目标数组,请你在数组中找出和为目标值target的那两个整数,并返回他们的数组下标
时间: 2023-08-14 16:16:34 浏览: 47
好的,可以使用暴力枚举或哈希表两种方法来解决这个问题。以下是两种方法的实现:
1. 暴力枚举
暴力枚举的思路比较简单,遍历每一个数,再遍历它后面的数,看是否存在两个数的和为target,时间复杂度为O(n^2)。
```
function twoSum(nums, target) {
for (let i = 0; i < nums.length; i++) {
for (let j = i + 1; j < nums.length; j++) {
if (nums[i] + nums[j] === target) {
return [i, j];
}
}
}
return [];
}
```
2. 哈希表
哈希表的思路是先将每个数和它的下标存入哈希表中,再遍历每一个数,查找哈希表中是否存在target-当前数的值,时间复杂度为O(n)。
```
function twoSum(nums, target) {
const hash = new Map();
for (let i = 0; i < nums.length; i++) {
if (hash.has(target - nums[i])) {
return [hash.get(target - nums[i]), i];
}
hash.set(nums[i], i);
}
return [];
}
```
以上两种方法都可以解决这个问题,但是哈希表的时间复杂度更低,因此更加优秀。
相关问题
给定一个整数数组和一个目标值,在数组中找出和为目标值的那两个整数
给定一个整数数组和一个目标值,可以通过以下步骤在数组中找出和为目标值的那两个整数:
1. 创建一个空字典,用于存储每个元素的值和它的索引。
2. 遍历数组中的每个元素:
- 检查目标值减去当前元素的差是否已经存在于字典中。
- 如果存在,说明找到了两个数的和为目标值,返回它们的索引。
- 如果不存在,将当前元素的值和索引添加到字典中。
以下是用于实现上述步骤的Python代码:
```python
def twoSum(nums, target):
num_dict = {}
for i, num in enumerate(nums):
complement = target - num
if complement in num_dict:
return [num_dict[complement], i]
num_dict[num] = i
```
给定整数数组nums和一个目标值target 在数组中找出和为目标值的两个整数 返回数组下标
题目描述:
给定一个整数数组 nums 和一个目标值 target,请在数组中找出和为目标值的两个整数,返回它们的数组下标。
示例:
输入:nums = [2, 7, 11, 15], target = 9
输出:[0, 1]
解释:nums[0] + nums[1] = 2 + 7 = 9,因此返回 [0, 1]。
思路:
暴力枚举法:对于每一个数,遍历整个数组,查找另一个数是否与它的和为目标值。
哈希表法:遍历数组,将每个数及其下标存储在哈希表中,同时查找哈希表中是否存在目标值减去当前数的差值。
代码实现:
暴力枚举法:
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
vector<int> res;
for (int i = 0; i < nums.size(); i++) {
for (int j = i + 1; j < nums.size(); j++) {
if (nums[i] + nums[j] == target) {
res.push_back(i);
res.push_back(j);
return res;
}
}
}
return res;
}
};
哈希表法:
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
vector<int> res;
unordered_map<int, int> map;
for (int i = 0; i < nums.size(); i++) {
if (map.find(target - nums[i]) != map.end()) {
res.push_back(map[target - nums[i]]);
res.push_back(i);
return res;
}
map[nums[i]] = i;
}
return res;
}
};