无序组合并将结果存储在r中的矩阵中

时间:2018-12-04 00:53:21

标签: r

说我有一个列表(a, b, c),我想找出它们的所有可能组合并存储在矩阵中,如:

      a b c
 [1,] 1 0 0
 [2,] 0 1 0
 [3,] 0 0 1
 [4,] 1 1 0
 [5,] 1 0 1
 [6,] 0 1 1
 [7,] 1 1 1`

我不知道该怎么做。感谢您的帮助!

2 个答案:

答案 0 :(得分:3)

要完全执行所需的操作,请使用permutations软件包中的gtools。其工作原理如下:

m <- permutations(2, 3, v=c(0,1), repeats.allowed=T)
colnames(m) <- c('a','b','c')
# delete [0,0,0]
m <- m[-1,]

收益:

     a b c
[1,] 0 0 1
[2,] 0 1 0
[3,] 0 1 1
[4,] 1 0 0
[5,] 1 0 1
[6,] 1 1 0
[7,] 1 1 1 

答案 1 :(得分:1)

想法来自此问题下的评论部分: Generate all combinations of length 2 using 3 letters

我的适应能力不是很好...但是似乎可以完成工作。

output <- expand.grid(rep(list(c('a', 'b', 'c')), 3))
colnames(output) <- c('a', 'b', 'c')
for (col in colnames(output)) { 
  output[, col] <- as.character(output[,col])
  output[, col] <- ifelse(output[, col]==col, 1, 0)
}
output <- output[!duplicated(output), ]
rownames(output) <- NULL
print(output)
# a b c
# 1 1 0 0
# 2 0 0 0
# 3 1 1 0
# 4 0 1 0
# 5 1 0 1
# 6 0 0 1
# 7 1 1 1
# 8 0 1 1