牛骨文教育服务平台(让学习变的简单)
博文笔记

LeetCode 两数之和

创建时间:2018-04-15 投稿人: 浏览次数:152

O(n)复杂度:利用哈希查找(即:map)来寻找某元素

注:Map是映射,别想成数组。

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int, int> m;
        vector<int> v;
        for(int i=0; i<nums.size(); i++) {
            m[nums[i]] = i;
        }
        for(int i=0; i<nums.size(); i++) {
            int temp = target - nums[i];
            if(m.count(temp) && m[temp] != i) {
                v.push_back(i);
                v.push_back(m[temp]);
                return v;
            }
        }
    }
};

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。