假设我有一个Python列表:
x = [3,6,4,8,1,9]
我希望在列表中找到元素的索引,它是子列表中的最小值(比如从索引2到4)。
因此,我想取一个子列表x[2:5]
,并获得最小元素的索引(在本例中是x[4]
)。
在这种情况下如何返回索引4?如果在子列表上使用np.argmin(),它将根据子列表返回索引(在本例中,np.argmin(x2:5)将返回2,这根据子列表是正确的)。
我不想使用多个if-否则条件。如何在短时间内得到这个指数?
发布于 2018-11-04 09:59:21
只需添加子列表开始的索引,您就可以得到原来的索引:
x = [3,6,4,8,1,9]
subl_start = 2
subl_end = 5
ind_min = np.argmin(x[subl_start: subl_end]) + subl_start
发布于 2018-11-04 10:03:12
还可以找到阈值之间的最小数字:
>>> x = [3,6,4,8,1,9]
>>> start, end = 2, 5
>>> min((e, i) for i, e in enumerate(x) if start <= i < end)[1]
4
或递增最终结果索引:
>>> min((e, i) for i, e in enumerate(x[start:end]))[1] + start
4
发布于 2018-11-04 10:12:47
我想这个班轮对你的案子没问题。
x.index(min(x[2:5]))
您也可以用一些变量替换2&5。(对于索引n到m -> (arrn:m+1))
https://stackoverflow.com/questions/53139545
复制相似问题