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

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

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理