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

解决该问题的思路是定义一个空的字典,然后遍历该列表,判断列表中的元素是否在字典中,若存在则次数加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()就是一个不错的方法

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值