首页 > 解决方案 > 查找列表的前 3 个最大值并将其位置保留在 Python 中的另一个列表中?

问题描述

我正在为我的 uni 论文用 Python 构建一个程序,我正在尝试找到一种方法来从带有浮点数的列表中找到前 3 个最大数字,这样我就可以将它们的位置保留在另一个列表中以供将来处理。

`maxim=max(listScore)
`i=0
`keep = [-1]*num
`for x in range(0,num):
````if listaScore[x]==maxim:
`````````keep[i]=x
`````````i+=1
`````````listScore[x]=-100
````maxim=max(listaScore)

the results i want is :

listScore=[0.25, 0.5, 0.5, -0.25, -0.25, 0.25]
positions=[1,2,5,-1,-1,-1]

标签: pythonlist

解决方案


这是使用列表推导的一种方法。这个想法是与列表sortrange长度相同,指定我们要从key参数中的列表中获取元素。我们得到的是排序后的结果range,以返回对列表进行排序的索引:

l= [0.25, 0.5, 0.5, -0.25, -0.25, 0.25]
out = [i for i in sorted(range(len(l)), key=l.__getitem__, reverse=True)][:3]
# [1, 2, 0]

如果你想要额外的-1s

out + [-1] * (len(l) - len(out))
# [1, 2, 0, -1, -1, -1]

推荐阅读