我们如何在R中生成所有可能的组合(可变长度,以便结果列表的长度为1,2或3,如果有3个元素)来自可变长度的向量:
# say we have a vector of length 3:
vec = letters[1:3]
ret = list('a', 'b', 'c', 'ab', 'ac', 'bc', 'abc', 'a,b', 'a,c', 'a,bc', 'b,c', 'ac,b', 'ab,c', 'a,b,c')
谢谢!
答案 0 :(得分:1)
这是一种方法,但对于较长的向量,它表现不佳。这可能是一种更简洁的方式,但在此期间这可能就足够了。
get_combos <- function(x) {
x2 <- unlist(lapply(seq_along(x), function(m)
sapply(combn(x, m, simplify=FALSE), paste0, collapse='')))
x3 <- expand.grid(rep(list(x2), length(x)))
x4 <- sapply(apply(x3, 1, unique), function(x) paste0(sort(x), collapse=','))
unique(grep('.*([^,]).*\\1', x4, val=TRUE, invert=TRUE))
}
get_combos(letters[1:3])
## [1] "a" "a,b" "a,c" "a,bc" "a,b,c" "b" "b,c" "ac,b"
## [9] "c" "ab,c" "ab" "ac" "bc" "abc"