题解 | #两数之和#
两数之和
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:如果没有找到,就将当前数值和坐标压入哈希表列中
查看13道真题和解析