题解 | #两数之和#

两数之和

http://www.nowcoder.com/practice/20ef0972485e41019e39543e8e895b7f

散列寻找

class Solution {
public:
    /**
     * 
     * @param numbers int整型vector 
     * @param target int整型 
     * @return int整型vector
     */
    vector<int> twoSum(vector<int>& numbers, int target) {
        // write code here
        int n = numbers.size();
        vector<int> ans(2, 0);
        unordered_map<int, int> mp;
        for (int i = 0; i < n; ++i) {
            if (mp.find(numbers[i]) == mp.end()) { // 哈希表中没有当前值
                mp[target - numbers[i]] = i+1;   // 将目标值与当前值的差值作为哈希值, 保存当前值的下标
            }
            else {  // 当前值在哈希表中
                ans[0] = mp[numbers[i]];
                ans[1] = i+1;
                return ans;  // 返回两数下标
            }
        }
        return ans;
    }
};
全部评论

相关推荐

07-07 14:30
复旦大学 Java
遇到这种人我也不知道说啥了
无能的丈夫:但我觉得这个hr语气没什么问题啊(没有恶意
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-09 12:11
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务