有一个序列集合,如[1,1,1,2,3,3,2]统计这个集合中所有元素出现的次数,如1出现的次数为3次,2出现2次

本文介绍了一种使用Python实现统计列表中元素出现次数的高效方法,包括普通for循环、内置函数reduce和利用set与列表的count方法。通过实例演示了不同方法的应用,适合Python初学者和数据处理需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

解决该问题的思路是定义一个空的字典,然后遍历该列表,判断列表中的元素是否在字典中,若存在则次数加1,若不存在则次数置为1,列表中的元素作为字典的key,出现的次数作为字典的value;

普通的for循环,代码如下:
def statics(li):
    dic={}
    for item in li:
        if not item in dic:
            dic[item]=1
        else:
            dic[item]+=1
    for item in dic:
        print '%s出现的次数:%s'%(item,dic[item])
采用python内建函数–reduce,代码如下:
def sta(dic,li):
    if not li in dic:
        dic[li]=1
    else:
        dic[li]+=1
l=[1,1,1,2,3,3,2]
print reduce(sta,l,{})      
采用内置set方法和列表的count方法,代码如下:
def sta(li):
    dic={}
    sli=set(li)
    for item in sli:
        dic[item]=li.count(item)
    return dic

set是一个无序不重复的元素集合,set是一种集合,当然可以使用 in/not in, len,即sets 支持 x in set, len(set),和 for x in set。count()方法用来计算列表中某一元素的个数
注:如何去除海量列表中的重复元素,set()就是一个不错的方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值