我想找到除 0 之外的最小值,这是我的代码:
A = 600000000
B = 450000000
C = 300000000
D = 150000000
E = 90000000
F = 60000000
G = 30000000
H = 15000000
rpl.list <- matrix(c(A,B,C,D,E,F,G,H),ncol=1)
apply(rpl.list, 2, FUN = function(x) {min(x[x > 0])})
结果是:
[1] 1.5e+07
并且该值在rpl.list[8]中,我想获取“8”值,这是该值的行号。如何获得? 我知道我可以循环 rpl.list 来查找与结果完全相同的值并返回 i,如下所示:
for(i in 1:nrow(rpl.list)){
if(rpl.list[i] == apply(rpl.list, 2, FUN = function(x) {min(x[x > 0])})){
temp = i
}
}
我想知道是否有一个简单的方法来返回行号
最佳答案
我们可以将小于或等于0的值替换为NA
后使用which.min
which.min(replace(rpl.list, rpl.list <= 0, NA))
关于r - 如何找到大于 0 的最低值并返回矩阵行索引?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51688182/