R:在每列中每两行查找最大值

标签 r matrix

我想在每列中找到每 2 行的最大值(比如说)。如何在 R 中做到这一点?例如

matrix(c(3,1,20,5,4,12,6,2,9,7,8,7), byrow=T, ncol=3) 

我想要这样的输出

matrix(c(5,4,20,7,8,9), byrow=T, ncol=3) 

最佳答案

这是一种方法。

  1. 定义一个向量,其中包含您想要的 groups 的相关信息。在这种情况下,我使用 rep 来重复一个数字序列。
  2. 然后定义一个辅助函数来计算数组的列最大值——这是一个简单的apply of max
  3. 最后,将 sapply 与一个匿名函数一起使用,该函数将 colMax 应用于每个分组的数组子集。

代码:

groups <- rep(1:2, each=2)
colMax <- function(x)apply(x, 2, max)
t(
    sapply(unique(groups), function(i)colMax(x[which(groups==i), ]))
)

结果:

     [,1] [,2] [,3]
[1,]    5    4   20
[2,]    7    8    9

关于R:在每列中每两行查找最大值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9921300/

相关文章:

c++ - 如何使用线性代数的C++模板库Eigen?

graphics - 旋转向量与四元数

r - R 中的 nnet, 'softmax = TRUE' 需要至少两个响应类别

r - 在图形上手动绘制

使用 agrep 对两个向量进行 R 模糊匹配

python - 使用 pandas 从字符串矩阵构造计数矩阵(整数)的方法(Python)

python - 在 python 中显示 rgb 矩阵图像

不同长度的 rbind 向量 : pad with zero (or NA) instead of recycling

R机器学习包处理大量级别的因素

r - 如何使用方差分析分数结果来消除 p 值大于 0.01 的列/预测变量