- 🔴力扣原题:
- 🟠题目简述:
- 🟡解题思路:
- 🟢C++代码:
- 🔵结果展示:
🔴力扣原题:
961. 在长度 2N 的数组中找出重复 N 次的元素
🟠题目简述:给你一个整数数组 nums ,该数组具有以下属性:
nums.length == 2 * n.
nums 包含 n + 1 个 不同的 元素
nums 中恰有一个元素重复 n 次
找出并返回重复了 n 次的那个元素。
- 哈希大法好;
- 利用
unordered_map
来计数; - 遍历
unordered_map
输出次数为n/2
的数字即可; - over;
class Solution {
public:
int repeatedNTimes(vector<int>& nums) {
int n = nums.size();
unordered_map<int, int> umap;
for(auto num : nums)
{
++umap[num];
}
for(auto it = umap.begin(); it != umap.end(); it++)
{
if(n/2 == it->second)
{
return it->first;
}
}
return -1;
}
};
🔵结果展示:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)