【发布时间】:2012-05-26 13:51:27
【问题描述】:
在 SO (LINK) 上的一个问题中,一位发帖人提出了一个问题,我给出了一个有效的答案,但有一部分让我感到困扰,从向量创建一个 list 以作为索引列表传递。所以说我有这个向量:
n <- 1:10
#> n
# [1] 1 2 3 4 5 6 7 8 9 10
假设我想将其分解为向量列表,每个向量的长度为 3。实现此目的的最佳(最短代码量和或最快)方法是什么?我们想丢弃第 10 项,因为它与 10/3 (length(n) - 10 %% 3) 有余数 1 (10 %% 3)。
这是想要的结果
list(1:3, 4:6, 7:9)
这将为我们提供那些不能组成三个一组的索引:
(length(n) + 1 - 10 %% 3):length(n)
编辑
这是 Wojciech Sobala 在 other thread 上发布的一个有趣的方法,链接到(我让他们在这里回答,如果他们回答,我会删除这个编辑)
n <- 100
l <- 3
n2 <- n - (n %% l)
split(1:n2, rep(1:n2, each=l, length=n2))
作为一个函数:
indices <- function(n, l){
if(n > l) stop("n needs to be smaller than or equal to l")
n2 <- n - (n %% l)
cat("numbers", (n + 1 - n %% l):n, "did not make an index of length", l)
split(1:n2, rep(1:n2, each=l, length=n2))
}
【问题讨论】:
-
所有很好的答案,但我认为 X,He's 是最短的代码。谢谢,这让我很烦。所有的方法都比我正在做的更好。
标签: r