我在下面的代码中遇到一些问题。我有两份名单,名字和分数。这些列表彼此对应,如下所示。我的目标是打印出两个列表中最好的前三个项目。我尝试将它们从最大到最小排序在一起,然后打印出前三项,但我得到了一些无边界错误。有什么想法吗?谢谢。
names = ['Xander', 'Spec', 'Meng', 'Sparc', 'Jones', 'Nick', 'Link']
scores = [120, 450, 300, 200, 66, 183, 80]
scores, names = (list(t) for t in zip(*sorted(zip(scores, names))))
print(names[:3] + " " + scores[:3])
输出示例:
Spec 450
Meng 300
Sparc 200
发布于 2019-03-12 03:26:13
您可以使用heapq.nlargest
from heapq import nlargest
for score, name in nlargest(3, zip(scores, names)):
print(name, score)
这将输出以下内容:
Spec 450
Meng 300
Sparc 200
发布于 2019-03-12 03:17:05
如果您的问题出在打印部分:
for i in range(3):
print(names[i], scores[i])
发布于 2019-03-12 03:22:33
你在最后一行的印刷是错误的。你不能像那样把list
对象和str
连接起来。改为执行以下操作:
scores, names = (list(t) for t in zip(*sorted(zip(scores, names), reverse=True)))
for i in range(3):
print(names[i], scores[i])
注意:reverse=True
用于按逆序对列表进行排序。
https://stackoverflow.com/questions/55108822
复制相似问题