使用迭代工具返回连续负数的最长列表。groupby [英] Return the longest list of consecutive negative numbers using itertools.groupby
本文介绍了使用迭代工具返回连续负数的最长列表。groupby的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
给定系列:
series = [2, 6, 9, -1, 1, -3, -3, -3, 1,-4]
如何使用itertools.groupby
返回列表[-3, -3, -3]
?
正在尝试:
from itertools import groupby
max((list(g) for k, g in groupby(series, key=lambda i: i < 0)), key=len)
退货:
[2, 6, 9]
提前谢谢
推荐答案
您可以这样做:
from itertools import groupby
series = [2, 6, 9, -1, 1, -3, -3, -3, 1, -4]
result = max((list(group) for key, group in groupby(series) if key < 0), key=len)
print(result)
输出
[-3, -3, -3]
您的代码的问题在于您在Groupby中使用了错误的键,key=lambda i: i < 0
,如果键是正数,请只筛选结果。
这篇关于使用迭代工具返回连续负数的最长列表。groupby的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文