题目描述🍗
给你一个整数数组 nums ,该数组具有以下属性:
nums.length == 2 * n.
nums 包含 n + 1 个 不同的 元素
nums 中恰有一个元素重复 n 次
找出并返回重复了 n 次的那个元素。
示例 1:
输入:nums = [1,2,3,3]
输出:3
示例 2:
输入:nums = [2,1,2,5,3,2]
输出:2
示例 3:
输入:nums = [5,1,5,2,5,3,5,4]
输出:5
算法分析 🍗
标签:哈希表
遍历一遍数组,统计每种数字出现的次数,然后返回次数等于n/2的元素
复杂度分析
时间复杂度:O(n)我们只需要对数组 nums\textit{nums}nums 进行一次遍历。
空间复杂度:O(n),即为哈希集合需要使用的空间。
完整代码 🍗
class Solution {
public: int repeatedNTimes(vector<int>& nums) { //这个数字刚好出现了一半 //哈希表 unordered_map<int,int>m; for(auto i:nums) m[i]++; int n=nums.size(); for(auto i:nums) {if(m[i]==n/2) return i; }return -1;//不可能的元素 }
};
本篇完!🍗