Python代码阅读(第39篇):获取列表出现频率最高的元素

本文介绍了Python代码实现获取列表中出现频率最高的元素的方法,来源于30-seconds-of-python库。函数通过创建元素集合去重,然后使用内置函数计算频率并找出最高频元素。

Python 代码阅读合集介绍:为什么不推荐Python初学者直接看项目源码

本篇阅读的代码实现了获取列表中出现频率最高的元素的功能。

本篇阅读的代码片段来自于30-seconds-of-python

most_frequent

def most_frequent(list):
  return max(set(list), key=list.count)

# EXAMPLES
most_frequent([1, 2, 1, 2, 3, 2, 1, 4, 2]) #2

most_frequent函数接收一个列表,返回出现频率最高的元素。

函数利用set(list)获取列表中元素的集合(去除重复元素),再使用maxlist.count寻找出现频率最高的元素。

set([iterable])方法从一个可迭代对象构建一个集合,集合容器中的元素具有唯一性,常用来进行成员检测、从序列中去除重复项以及数学中的集合类计算等。在本代码片段中,用于对传入的list参数进行去重。

>>> set([1, 2, 1, 2, 3, 2, 1, 4, 2])
{1, 2, 3, 4}

max(set(list), key=list.count)函数会根据关键词参数key=list.count所指定带有一个参数的函数,用于从每个列表元素中提取比较键。list.count(x)会返回xlist中出现的次数。max函数会返回比较键(出现次数)最大的元素。

>>> [1, 2, 1, 2, 3, 2, 1, 4, 2].count(1)
3
>>> [1, 2, 1, 2, 3, 2, 1, 4, 2].count(2)
4
>>> [1, 2, 1, 2, 3, 2, 1, 4, 2].count(3)
1
>>> [1, 2, 1, 2, 3, 2, 1, 4, 2].count(4)
1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值