Python
 Computer >> コンピューター >  >> プログラミング >> Python

Pythonプログラムの辞書で最も高い3つの値を見つける


この記事では、以下に示す問題ステートメントの解決策について学習します。

問題の説明 −辞書が与えられたので、辞書の中で最も高い3つの値を出力する必要があります。

以下で説明するように、2つのアプローチがあります

アプローチ1:Collections.counter()関数の使用

# collections module
from collections import Counter
# Dictionary
my_dict = {'T': 23, 'U': 22, 'T': 21,'O': 20, 'R': 32, 'S': 99}
k = Counter(my_dict)
# 3 highest values
high = k.most_common(3)
print("Dictionary with 3 highest values:")
print("Keys : Values")
for i in high:
   print(i[0]," : ",i[1]," ")

出力

Dictionary with 3 highest values:
Keys : Values
S : 99
R : 32
U : 22

ここで、mostcommon()メソッドは、n個の最も一般的な要素と、最も一般的な要素から最も一般的でない要素までのカウントのリストを返します。

nlargest.heapq()関数を使用したアプローチ2

# nlargest module
from heapq import nlargest
# Dictionary
my_dict = {'T': 23, 'U': 22, 'T': 21,'O': 20, 'R': 32, 'S': 99}
ThreeHighest = nlargest(3, my_dict, key = my_dict.get)
print("Dictionary with 3 highest values:")
print("Keys : Values")
for val in ThreeHighest:
   print(val, " : ", my_dict.get(val))

出力

Dictionary with 3 highest values:
Keys : Values
S : 99
R : 32
U : 22

ここでは、3つの引数をとるn個の最大の要素を使用しました。1つは選択する要素の数であり、他の2つの引数(辞書とそのキー)です。

結論

この記事では、辞書で最も高い3つの値を見つける方法を学びました


  1. 行列の転置を見つけるPythonプログラム

    この記事では、特定の問題ステートメントを解決するための解決策とアプローチについて学習します。 問題の説明 行列が与えられた場合、転置を同じ行列に格納して表示する必要があります。 行列の転置は、行を列に、列を行に変更することで得られます。つまり、A行列の転置はA[i][j]をA[j][i]に変更することで得られます。 以下に示す実装を見てみましょう- 例 N = 4 def transpose(A):    for i in range(N):       for j in range(i+1, N):     &nbs

  2. 配列の合計を見つけるPythonプログラム

    この記事では、特定の問題ステートメントを解決するための解決策とアプローチについて学習します。 問題の説明 入力として配列が与えられた場合、与えられた配列の合計を計算する必要があります。 ここでは、ブルートフォースアプローチに従うことができます。つまり、リストをトラバースし、各要素を空の合計変数に追加します。最後に、合計の値を表示します。 以下で説明するように、組み込みの合計関数を使用して別のアプローチを実行することもできます。 例 # main arr = [1,2,3,4,5] ans = sum(arr,n) print ('Sum of the array is '