使用R查找包含最大值的行索引

时间:2009-04-13 11:13:52

标签: r matrix

给定以下矩阵假设我想在第二列中找到最大值:

mat <- matrix(c(1:3,7:9,4:6), byrow = T, nc = 3)
mat
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    7    8    9
[3,]    4    5    6

我知道max(mat[,2])将返回8.如何返回行索引,在本例中是第二行?

3 个答案:

答案 0 :(得分:163)

请参阅?which.max

> which.max( matrix[,2] )
[1] 2

答案 1 :(得分:27)

请参阅?order。你只需要最后一个索引(或者首先是递减的顺序),所以这应该可以解决问题:

order(matrix[,2],decreasing=T)[1]

答案 2 :(得分:2)

以下内容如何,​​其中y是矩阵的名称,您正在寻找整个矩阵中的最大值:

row(y)[y==max(y)]

如果要提取行:

y[row(y)[y==max(y)],] # this returns unsorted rows.

要返回已排序的行,请使用:

y[sort(row(y)[y==max(y)]),]

这种方法的优点是您可以将条件内部更改为您需要的任何内容。此外,使用col(y)和悬挂逗号的位置,您还可以提取列。

y[,col(y)[y==max(y)]]

要查找特定列中max的行,例如第2列,您可以使用:

seq(along=y[,2])[y[,2]==max(y[,2])]

再次条件灵活地寻找不同的要求。

有关其他想法,请参阅Phil Spector出色的“S和S-Plus简介”第5章。