1. ホーム
  2. python

[解決済み] reduce を辞書で引くとこんな感じ。

2022-02-19 07:52:14

質問

Pythonの辞書でreduceを使用する方法について理解するのに問題があります。例えば、私は次のような辞書を持っています。

{1: 3, 2: 1, 3: 2}

を計算しようとしているのですが、以下のようになります。

s = 0
for i in h:
    s += h[i] * (h[i] - 1)

これは期待通りに機能する(得られる。 8 しかし、これをreduceパラダイムに変換しようとすると、失敗します。 reduce(lambda x, y: x + y * (y - 1), h) しかし、私は間違った答えを受け取っています。

これは、値ではなくキーを使っているためだと思われます。どうすれば、私のコードを適切に縮小できるようになりますか?

どのように解決するのですか?

初期値ゼロで辞書を減らしながら反復処理する必要があります。

辞書を繰り返し処理する場合、実際にはキーを繰り返し処理するので、値を取得するために辞書のインデックスを作成する必要があることに注意してください。

reduce(lambda x, key:x + h[key] * (h[key] - 1), h, 0)

あるいは、辞書の値にしか興味がなく、キーについてはあまり気にしないので、辞書の値について繰り返し処理を行うだけです。

Python 2.X

reduce(lambda x, value:x + value * (value - 1), h.itervalues(), 0)

Python 3.X

reduce(lambda x, value:x + value * (value - 1), h.values(), 0)