web-dev-qa-db-ja.com

辞書から最大値を返します

辞書から最大値とそのキーを返したいのですが、次のようなものがトリックを行う必要があることを知っています

max(list.iteritems(), key=operator.itemgetter(1))

ただし、ディクショナリの最大値が6で、複数のキーが同じ値を持つ場合は、常に最初のキーが返されます!値とともに値として最大数を持つすべてのキーを返すようにするにはどうすればよいですか。同じ最大値を持つ辞書の例を次に示します。

dic={0: 1.4984074067880424, 1: 1.0984074067880423, 2: 1.8984074067880425, 3: 2.2984074067880425, 4: 2.2984074067880425}
7
Ophilia

リスト内包表記を使用したソリューション:

dic={0: 1.4984074067880424, 1: 1.0984074067880423, 2: 1.8984074067880425, 3: 2.2984074067880425, 4: 2.2984074067880425}
max_value = max(dic.values())  # maximum value
max_keys = [k for k, v in dic.items() if v == max_value] # getting all keys containing the `maximum`

print(max_value, max_keys)

出力:

2.2984074067880425 [3, 4]
19
RomanPerekhrest

最初に最大値を決定できます:

maximum = max(dic.values())

そして、最大値に基づいてfilter

result = filter(lambda x:x[1] == maximum,dic.items())

コマンドラインの例:

$ python2
Python 2.7.12 (default, Nov 19 2016, 06:48:10) 
[GCC 5.4.0 20160609] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> dic={0: 1.4984074067880424, 1: 1.0984074067880423, 2: 1.8984074067880425, 3: 2.2984074067880425, 4: 2.2984074067880425}
>>> maximum=max(dic.values())
>>> maximum
2.2984074067880425
>>> result = filter(lambda x:x[1] == maximum,dic.items())
>>> result
[(3, 2.2984074067880425), (4, 2.2984074067880425)]

キーのリストがNiceリストと値であることを示したい場合、関数を定義できます:

def maximum_keys(dic):
    maximum = max(dic.values())
    keys = filter(lambda x:dic[x] == maximum,dic.keys())
    return keys,maximum

キーのリストと最大値を含むタプルを返します:

>>> maximum_keys(dic)
([3, 4], 2.2984074067880425)
2