题解 | #两数之和#

两数之和

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

1.遍历一次解决问题

#include<map>

class Solution {
public:
    /**
     * 
     * @param numbers int整型vector 
     * @param target int整型 
     * @return int整型vector
     */
    vector<int> twoSum(vector<int>& numbers, int target) {
        // write code here
        vector<int> res =vector<int>();
        map<int,int> mark = map<int, int>();
        for(int i=0;i<numbers.size();i++) {
            int x = target-numbers[i];
            if (mark.find(x)!=mark.end() && mark[x]!=i) {
                res.push_back(mark[x]+1);
                res.push_back(i+1);
                return res;
            }
            mark[numbers[i]] = i;
        }
        return res;
    }
};
全部评论

相关推荐

07-18 10:39
门头沟学院 Java
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-15 12:20
点赞 评论 收藏
分享
流浪的神仙:无恶意,算法一般好像都得9硕才能干算法太卷啦
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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