python 输出列表中出现最多的n个_Python – 返回N个列表中最大的一个

使用密钥= len的

max.

In [3]: max([l1, l2], key=len)

Out[3]: [4, 5, 6, 7]

这将检索列表列表的(第一个)最长列表.

实际上,这也适用于字符串(以及具有len属性的其他对象).

In [4]: max(['abcd', 'ab'], key=len)

Out[4]: 'abcd'

In [5]: max([(1, 2), (1, 2, 3), (1,)], key=len)

Out[5]: (1, 2, 3)

In [6]: max(['abc', [1, 2, 3]], key=len)

Out[6]: 'abc'

注意:我们也可以将这些项作为参数传递:

In [7]: max(l1, l2, key=len)

Out[7]: [4, 5, 6, 7]

max reads:从密钥的角度看(当你传递密钥时)给我一个列表中最大的项目.

它大致相当于下面的代码*(在python 3中),但实际的源是written in C(效率更高,实际测试的更多,所以请继续使用max而不是这个!):

def my_max(*L, key=None): # in python 2 we'd need to grab from kwargs (and raise type error if rogue keywords are passed)

L = list(L[0]) if len(L) == 1 else L # max takes iterable as first argument, or two or more arguments...

if not L:

raise ValueError("my_max() arg is an empty sequence")

if key is None: # if you don't pass a key use the identity

key = lambda x: x

max_item, max_size = L[0], key(L[0])

for item in L[1:]:

if key(item) > max_size:

max_item, max_size = item, key(item)

return max_item

*我把它作为练习使用迭代器而不是列表来编写…并修复任何其他错误!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值