在矩阵中查找最大值的行和列索引

ric*_*rdo 52 r matrix

我希望找到矩阵的最大元素值及其位置(矩阵中的行和列id).

我使用以下函数返回矩阵的行和列.

这似乎是一个糟糕的黑客 - 这是我可能错过本机方法的事情.是否有更好/ 更多的R方式?

这是我的功能:

matxMax <- function(mtx)
{
    colmn <- which(mtx == max(mtx)) %/% nrow(mtx) + 1
    row <- which(mtx == max(mtx)) %% nrow(mtx)
    return( matrix(c(row, colmn), 1))
}
Run Code Online (Sandbox Code Playgroud)

我用的如下:

mm <- matrix(rnorm(100), 10, 10)
maxCords <- matxMax(mm)
mm[maxCords]
Run Code Online (Sandbox Code Playgroud)

Qua*_*bex 105

你可以做到

## Some data
set.seed(123)
mm <- matrix(rbinom(40, 20, 0.5), 8, 5)
mm
#      [,1] [,2] [,3] [,4] [,5]
# [1,]    9   10    8   11   11
# [2,]   12   10    6   11   12
# [3,]    9   14    9   10    6
# [4,]   13   10   14   11   10
# [5,]   13   11   13    9   12
# [6,]    6   10   11    8    8
# [7,]   10    7   11   14    9
# [8,]   13   13   16   13    8

which(mm == max(mm), arr.ind = TRUE)
#      row col
# [1,]   8   3
Run Code Online (Sandbox Code Playgroud)

  • 有没有办法找到第二个最大值的位置?第二个最大值可以与第一个最大值相同,在这种情况下,我想得到第二个最大值的位置,它与第一个最大值完全相同. (3认同)
  • @ user2543622,您是否在设置中的示例中尝试了建议的解决方案?所提出的解决方案提供矩阵的所有元素的列表,其等于最大值.所以,如果有关系,你会得到所有. (3认同)