1、题目描述
https://leetcode-cn.com/problems/unique-number-of-occurrences/
给你一个整数数组 arr
,请你帮忙统计数组中每个数的出现次数。
如果每个数的出现次数都是独一无二的,就返回 true
;否则返回 false
。
输入:arr = [1,2,2,1,1,3]
输出:true
解释:在该数组中,1 出现了 3 次,2 出现了 2 次,3 只出现了 1 次。没有两个数的出现次数相同。
输入:arr = [1,2]
输出:false
输入:arr = [-3,0,1,-3,1,1,1,-3,10,0]
输出:true
2、代码详解
两个dict
- 第一个dict统计词频
- 第二个dict用来看之前的词频是否有一样的
class Solution(object):
def uniqueOccurrences(self, arr):
"""
:type arr: List[int]
:rtype: bool
"""
count_dict = {}
for word in arr:
if word not in count_dict:
count_dict[word] = 1
else:
count_dict[word] += 1
# 次数的次数
count_again = {}
for k in count_dict:
if count_dict[k] in count_again: # 有相同次数的
return False
else:
count_again[count_dict[k]] = 1
return True
首先证明:不可能一次遍历arr得到解。
因为没有遍历完之前是不知道每个数出现的次数的。没法判断是否有同样次数的存在。
所以先要遍历arr得到每个数出现的次数,可以用字典或者列表。
然后再遍历次数,得到次数的次数只要不是1,就是有同样的次数出现两次。返回False即可。