做个简单题 要不然就自闭了。。。。
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
(题目链接)https://leetcode-cn.com/problems/two-sum/submissions/
604 ms 7.1 MB
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
for (int i = 0; i < nums.size(); i++) {
for (int j = i + 1; j < nums.size(); j++) {
if (nums[i] + nums[j] == target) {
vector<int> ans{ i,j };
return ans;
}
}
}
vector<int> ans;
return ans;
}
};
使用 stl库 unordered_map 只遍历一遍。。。。 这个就很舒服了
8 ms 8.2 MB
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
unordered_map<int, int> tar;
vector <int> ans;
for (int i = 0; i < nums.size(); i++) {
int currentmap = target - nums[i];
if (tar.count(currentmap)) {
ans.push_back(tar[currentmap]);
ans.push_back(i);
return ans;
}
tar.insert(pair<int,int>(nums[i], i));
}
return ans;
}
};
很久之前做的了 没想到今天的每日一题是这个。。。。。