题目描述
给你一个整数数组 arr,请你帮忙统计数组中每个数的出现次数。
如果每个数的出现次数都是独一无二的,就返回 true;否则返回 false。
示例 1:
输入:arr = [1,2,2,1,1,3]
输出:true
解释:在该数组中,1 出现了 3 次,2 出现了 2 次,3 只出现了 1 次。没有两个数的出现次数相同。
示例 2:
输入:arr = [1,2]
输出:false
示例 3:
输入:arr = [-3,0,1,-3,1,1,1,-3,10,0]
输出:true
提示:
1 <= arr.length <= 1000
-1000 <= arr[i] <= 1000
来源:力扣(LeetCode)
题解
看题目一目了然,最先做的事情就是记录每个数字出现的次数,最好的莫过于map。
将出现次数记录下来之后,要考虑怎么来分辨map中是否有重复的次数。
一个很巧妙的做法是使用set,利用set中元素唯一的性质,将set的大小和map进行比较,大小一样则没有重复元素,反之有重复。
class Solution {
public:
bool uniqueOccurrences(vector<int>& arr) {
unordered_map<int,int> m;
for(int i=0;i<arr.size();i++){
m[arr[i]]++;
}
set<int> s;
for(auto p:m){
s.insert(p.second);
}
return s.size()==m.size();
}
};