题解 | #两数之和#

两数之和

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

#include <map>
#include<iostream>
#include<cstdio>
class Solution {
  public:
    /**
     *
     * @param numbers int整型vector
     * @param target int整型
     * @return int整型vector
     */
    vector<int> twoSum(vector<int>& numbers, int target) {
    vector<int> res;
    map<int, int> hash;
    for (int i = 0; i < numbers.size(); i++) {
        // 寻找target不如寻找target和number的差值,并且map插入新的键值对也是在end插入的
        if (hash.find(target - numbers[i]) != hash.end()) {
            res.push_back(hash[target - numbers[i]] + 1);
            res.push_back(i + 1);
            return res;
            }
            hash[numbers[i]] = i;
        }
        return res;
    }

};

全部评论

相关推荐

不愿透露姓名的神秘牛友
今天 12:05
点赞 评论 收藏
分享
06-07 12:20
新余学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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