题目:
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
方法一代码:
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
int len = nums.size();
for(int i = 0;i < len;i++) {
for(int j = i + 1;j < len;j++) {
if(nums[i] + nums[j] == target) {
return {i,j};
}
}
}
return {};
}
};
题意:给定一个数组和目标值,找出数组中两个数,这两个数相加正好等于目标值,然后返回这两个数的下标。
思路:一开始想到暴力法,两边循环两两配对,返回下表,这种方法时间复杂度为o(n^2)。
方法二代码:
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
int lens = nums.size();
unordered_map<int,int> map;
for(int i = 0;i < lens;i++) {
map[nums[i]] = i;
}
for(int i = 0;i < lens;i++) {
if(map.find(target - nums[i]) != map.end() && map[target - nums[i]] != i) {
return {i,map[target - nums[i]]};
}
}
return {};
}
};
思路:
随后想到用哈希表来完成,对每一个数组中的元素都保存在哈希表中作为键,并且给每一个元素都配有一个值,这个值就是该元素的数组下标,随后遍历数组元素,如果目标值减去该元素在表中存在而且找到的元素不是本身就返回这两个下标。这种方法时间复杂度为o(n^2)