题解 | #两数之和#

两数之和

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

这个解法主要是利用unordered_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
        int n = numbers.size();
        vector<int> res;
        if(n == 0){
            return res;
        }

        unordered_map<int, int> hashmap;
        for(int i = 0;i < n; i++){
            if(hashmap.find(target - numbers[i]) != hashmap.end()){ @1
                res.push_back(hashmap[target - numbers[i]] + 1); @2
                res.push_back(i + 1);                            @3
                break;
            }else{
                hashmap[numbers[i]] = i;                           @4
            }
        }
        return res;
    }
};

@1:在哈希表中查找目标值和当前值相减后是否有一样的,如果有一样的 则进入@2
@2:将哈希表找到的位置的最表的下标压入vector
@3:将当前位置记录的下标压入vector
@4:如果没有找到,就将当前数值和坐标压入哈希表列中

全部评论

相关推荐

半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
湫湫湫不会java:1.在校经历全删了2.。这些荣誉其实也没啥用只能说,要的是好的开发者不是好好学生3.项目五六点就行了,一个亮点一俩行,xxx技术解决,xxx问题带来xxx提升。第一页学历不行,然后啥有价值的信息也没有,到第二页看到项目了,第一个项目九点,第二个项目像凑数的俩点。总体给人又臭又长,一起加油吧兄弟
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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