两种解法
- map, two pass (可以优化为 one pass)
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
vector<int> v;
if (nums.size() < 2) return v;
unordered_map<int, int> m;
for (int i = 0; i < nums.size(); i++) {
m[nums[i]] = i;
}
for (int i = 0; i < nums.size(); i++) {
if (m.find(target - nums[i]) != m.end() && i != m[target - nums[i]]) {
v.push_back(i);
v.push_back(m[target - nums[i]]);
break;
}
}
return v;
}
};
用 vector<int, int> 存储 num + index, 然后通过 vector<int, int> 中的num 进行排序,用两个指针夹逼获取target,取出对应的 index 即是结果