该题实际上有两种解法。第一是使用Python的字典计数即可,第二种方法则是按位计算。借这个机会记录一下使用字典统计列表中数字个数的一些方法
方法一:利用字典的get函数,get表示根据字典的key取它的value值,如果该key不存在,则value值会默认为get的第二个参数。
values=[1,2,3,2,3,1,4]
values_cnt={}
for value in values:
value_cnt[value]=values_cnt.get(value,0)+1
方法二:定义一个新的计数字典,用来放元素及其个数。为了防止产生异常,应该判断计数字典中是否有该元素,这样才能作为可key来进行访问。
list1=[1,3,2,4,2,3]
dict_cnt={} #dict_cnt=dict()
for item in list1:
if item in dict_cnt: #直接判断key在不在字典中
dict_cnt[item]+=1
else:
dict_cnt[item]=1
方法三:利用collections中的defaultdict()
defaultdict()可以接受一个参数,如str,int,float等。但这个参数并不是来约束字典的key的值的类型,也不是用来约束value的值的类型。而是当字典的key不存在时,将value初始化为某个值。str初始化为“”,int初始化为0,float初始化为0.0。
from collections import defaultdict
list1=[1,2,3,4,3,2]
count_dict=defaultdict(int)
for item in lists:
count_dict[item]+=1
方法四:利用collections中的Counter函数
from collections import Counter
list1=[1,2,3,4,3,2,1]
a=Counter(list1)
print(a) # Counter({1:2,2:2,3:2,4:1})
a.elements() #获取a中的所有的键,返回的是一个对象,可以通过list来转化它
a.most_common(2) #返回前两个出现频率最高的以及他们的键,列表里面嵌套元祖的方式
a['123'] #访问不存在的时候,自动返回为0
a.update("dfwfw") #更新被统计的对象,即原有的计数值与新增的相加,而不是替换
a.subtrct("WEwggw") #实现与原来的计数值相减,结果运行为0和负值