12

次のような多次元配列があるとします。

[
   [.1, .2, .9],
   [.3, .4, .5],
   [.2, .4, .8]
]

各サブ配列 ( ) から最高値を含む 1 次元配列を返すための最良の*方法は何でしょう[.9,.5,.8]か? 以下のようなことを手動で行うことができると思います:

newArray = []
for subarray in array:
   maxItem = 0
   for item in subarray:
       if item > maxItem:
           maxItem = item
   newArray.append(maxItem)

しかし、これを行うためのよりクリーンな方法があるかどうか興味がありますか?

*この場合、ベスト = コードの行数が最も少ない

4

7 に答える 7

13

これを試して:

max(array.flatten())
于 2013-04-10T05:00:54.307 に答える
11

コメントでnumpyを使用していると述べたので...

>>> import numpy as np
>>> a = np.random.rand(3,3)
>>> a
array([[ 0.43852835,  0.07928864,  0.33829191],
       [ 0.60776121,  0.02688291,  0.67274362],
       [ 0.2188034 ,  0.58202254,  0.44704166]])
>>> a.max(axis=1)
array([ 0.43852835,  0.67274362,  0.58202254])

編集: ドキュメントはこちら

于 2013-04-10T04:53:14.170 に答える
4

リスト内包表記の使用:

maxed = [max(sub_array) for sub_array in array]
于 2013-04-10T04:45:00.347 に答える