如果我想获得矢量的所有子集,我可以使用sets
包:
library(sets)
v <- c("test1", "test2", "test3", "test4")
set_power(v)
## {{}, {"test1"}, {"test2"}, {"test3"}, {"test4"}, {"test1",
## "test2"}, {"test1", "test3"}, {"test1", "test4"}, {"test2",
## "test3"}, {"test2", "test4"}, {"test3", "test4"}, {"test1",
## "test2", "test3"}, {"test1", "test2", "test4"}, {"test1",
## "test3", "test4"}, {"test2", "test3", "test4"}, {"test1",
## "test2", "test3", "test4"}}
Run Code Online (Sandbox Code Playgroud)
我的问题我
如何只获得所有元素都是连续的所有子集,所以在上面的例子中没有{"test1", "test3"}, {"test1", "test4"}, {"test2", "test4"}, {"test1", "test2", "test4"}, {"test1", "test3", "test4"}
G. *_*eck 15
试试rollapply
这样:
library(zoo)
v <- c("test1", "test2", "test3", "test4")
L <- lapply(seq_along(v), rollapply, data = v, c)
L[[1]] <- matrix(L[[1]])
Run Code Online (Sandbox Code Playgroud)
给出length(v)
组件,每个子集大小一个:
[[1]]
[,1]
[1,] "test1"
[2,] "test2"
[3,] "test3"
[4,] "test4"
[[2]]
[,1] [,2]
[1,] "test1" "test2"
[2,] "test2" "test3"
[3,] "test3" "test4"
[[3]]
[,1] [,2] [,3]
[1,] "test1" "test2" "test3"
[2,] "test2" "test3" "test4"
[[4]]
[,1] [,2] [,3] [,4]
[1,] "test1" "test2" "test3" "test4"
Run Code Online (Sandbox Code Playgroud)
或者作为每个子集包含一个组件的平面列表:
flat <- do.call("c", lapply(L, function(x) split(x, 1:nrow(x))))
Run Code Online (Sandbox Code Playgroud)
赠送:
> str(flat)
List of 10
$ 1: chr "test1"
$ 2: chr "test2"
$ 3: chr "test3"
$ 4: chr "test4"
$ 1: chr [1:2] "test1" "test2"
$ 2: chr [1:2] "test2" "test3"
$ 3: chr [1:2] "test3" "test4"
$ 1: chr [1:3] "test1" "test2" "test3"
$ 2: chr [1:3] "test2" "test3" "test4"
$ 1: chr [1:4] "test1" "test2" "test3" "test4"
Run Code Online (Sandbox Code Playgroud)
akr*_*run 10
一个base R
选择是embed
lapply(seq_along(v), function(i) embed(v, i)[, i:1, drop = FALSE])
#[[1]]
# [,1]
#[1,] "test1"
#[2,] "test2"
#[3,] "test3"
#[4,] "test4"
#[[2]]
# [,1] [,2]
#[1,] "test1" "test2"
#[2,] "test2" "test3"
#[3,] "test3" "test4"
#[[3]]
# [,1] [,2] [,3]
#[1,] "test1" "test2" "test3"
#[2,] "test2" "test3" "test4"
#[[4]]
# [,1] [,2] [,3] [,4]
#[1,] "test1" "test2" "test3" "test4"
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
354 次 |
最近记录: |