2

例如,如果给定的字典如下:

dic = {('K1', 'S1'): 4.999997655759467, 
       ('k1', 'K2'): 6.1999036349232375, 
       ('K1', 'K4'): 7.999999999999876, 
       ('K2', 'K1'): 6.199940422452897, 
       ('K2', 'K3'): 7.999999999999876, 
       ('K2', 'K5'): 6.199962763954776, 
       ('K3', 'K2'): 6.199997321675397, 
       ('K3', 'K6'): 7.999998023783301, 
       ('K3', 'S2'): 9.999999999999911, 
       ('K4', 'S1'): 9.999999999999911, 
       ('K4', 'K1'): 6.199999975663285, 
       ('K4', 'K5'): 6.19999999303405, 
       ('K5', 'K2'): 6.199989058277423, 
       ('K5', 'K4'): 7.999999999999876, 
       ('K5', 'K6'): 7.999950953156936, 
       ('K6', 'S2'): 9.999999999999911, 
       ('K6', 'K3'): 7.999641214892367, 
       ('K6', 'K5'): 6.19980050493078}

所需的输出如下:

{('K1', 'K4'): 7.999999999999876,
 ('K2', 'K3'): 7.999999999999876,
 ('K3', 'S2'): 9.999999999999911,
 ('K4', 'S1'): 9.999999999999911,
 ('K5', 'K4'): 7.999999999999876,
 ('K6', 'S2'): 9.999999999999911}

我实现了下面的函数,可惜它只能获取到value,并没有获取到对应的key。

def getMaxForX(number):
    return max([v for k, v in dic.items() if k[0] == number])

我不完全理解字典的最大键和值的概念?

请建议我如何解决这个问题。

4

2 回答 2

0

所以你想按键的第一个元素(K1, K2, K3, ...)分组,然后根据值找到每个组的最大值:

>>> from itertools import groupby
>>> sortkey = lambda i: i[0][0].lower()
>>> groups = groupby(sorted(dic.items(), key=sortkey), key=sortkey)
>>> result = dict(max(v, key=lambda i: i[1]) for k, v in groups)
>>> result
{('K1', 'K4'): 7.999999999999876, ('K2', 'K3'): 7.999999999999876, ('K3', 'S2'): 9.999999999999911, ('K4', 'S1'): 9.999999999999911, ('K5', 'K4'): 7.999999999999876, ('K6', 'S2'): 9.999999999999911}

注意:我sortkey在分组时使用了 a ,因为您示例中的一个键具有不同的大小写。如果这只是一个错字,你可以省略它。

于 2019-11-12T13:39:26.173 回答
0

我猜你只是附加值(v)而不是键(k)。return所以更新你的逻辑

return max([k, v for k, v in Q_values.items() if k[0] == number])
于 2019-11-12T13:05:50.470 回答