我想获取列表中最小项目的索引,但以防平局。我想使用两个最小项目的位置并在另一个列表中比较这些位置。
order = [4, 1 ,2 ,1 ]
LPT = [20, 10, 5, 20]
new_order = []
我想从订单列表中的最小值获取索引,如果出现平局,则使用 LPT 中同一位置的最大值。
new_order
应该是这样的:
new_order = [3,1,2,0]
最佳答案
使用列表理解:
[x for x, _ in sorted(enumerate(zip(order, LPT)), key=lambda x: (x[1][0], -x[1][1]))]
代码:
order = [4, 1, 2, 1]
LPT = [20, 10, 5, 20]
new_order = [x for x, _ in sorted(enumerate(zip(order, LPT)), key=lambda x: (x[1][0], -x[1][1]))]
# [3, 1, 2, 0]
关于python - 获取列表中最小项目的索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55662545/