我有一个如下的numpy矩阵
[['- A B C D E']
['A 0 2 3 4 5']
['B 2 0 3 4 5']
['C 3 3 0 4 5']
['D 4 4 4 0 5']
['E 5 5 5 5 0']]
如何在此矩阵中找到最小值以及该最小值的索引,在考虑最小值时,排除所有零?
我尝试了几种在网上看到的方法,但几乎总是会收到以下错误:TypeError: cannot perform reduce with flexible type
我希望尝试使用任何新的解决方案并检查其是否有效?
答案 0 :(得分:2)
您需要使用“ numpy”矩阵返回到绘图板,该矩阵不是矩阵,而是(单个)字符串列表的列表。
x =['- A B C D E',
'A 0 2 3 4 5',
'B 2 0 3 4 5',
'C 3 3 0 4 5',
'D 4 4 4 0 5',
'E 5 5 5 5 0']
# Preprocess this matrix to make it a matrix
x = [e.split() for e in x]
numbers = set("0123456789")
xr = [[float(e) if all(c in numbers for c in e) and e != "0" else float("inf") for e in l] for l in x]
所有非数字或0的内容都标记为float(inf),以免影响最小值计算:
[[inf, inf, inf, inf, inf, inf],
[inf, inf, 2.0, 3.0, 4.0, 5.0],
[inf, 2.0, inf, 3.0, 4.0, 5.0],
[inf, 3.0, 3.0, inf, 4.0, 5.0],
[inf, 4.0, 4.0, 4.0, inf, 5.0],
[inf, 5.0, 5.0, 5.0, 5.0, inf]]
然后,您可以轻松地使用numpy的argmin
和unravel_index
来获取所需的内容。
xrn = np.array(xr)
index = np.unravel_index(np.argmin(xrn), xrn.shape)
# RESULT: (1, 2)