EP1 Two Sum

两种解法

  • 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;
    }
};
  • sort + one pass
用 vector<int, int> 存储 num + index, 然后通过 vector<int, int> 中的num 进行排序,用两个指针夹逼获取target,取出对应的 index 即是结果

推荐阅读更多精彩内容