假设我有一个多维数组,如下所示:
[
[.1, .2, .9],
[.3, .4, .5],
[.2, .4, .8]
]
返回包含每个子数组([.9,.5,.8]
)中最高值的单维数组的最佳方法是什么?我假设我可以手动执行以下操作:
newArray = []
for subarray in array:
maxItem = 0
for item in subarray:
if item > maxItem:
maxItem = item
newArray.append(maxItem)
但我很好奇是否有更清洁的方法可以做到这一点?
*在这种情况下,最好=最少的代码行
答案 0 :(得分:12)
试试这个:
max(array.flatten())
答案 1 :(得分:11)
map
的 max
是更清洁的IMO。
>>> arr = [
... [.1, .2, .9],
... [.3, .4, .5],
... [.2, .4, .8]
... ]
>>> map(max, arr)
[0.9, 0.5, 0.8]
答案 2 :(得分: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])
修改:文档为here
答案 3 :(得分:4)
使用列表理解:
maxed = [max(sub_array) for sub_array in array]
答案 4 :(得分:2)
map(max,my_array)
我认为那很短暂......
答案 5 :(得分:0)
也许使用max函数
代替第二个for循环答案 6 :(得分:0)
您可以使用numpy
import numpy as np
w = [[2,3,4],[5,6,7],[1,2,11]]
h=[]
for i in w:
h.append(np.amax(i))
print(h)