Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/visual-studio-2008/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
R 按矩阵中的行获取所有可能的组合_R_Matrix_Combinations_Combn - Fatal编程技术网

R 按矩阵中的行获取所有可能的组合

R 按矩阵中的行获取所有可能的组合,r,matrix,combinations,combn,R,Matrix,Combinations,Combn,我有一个mxn矩阵,如下所示: 1 2 3 4 5 6 按行获取所有可能组合的最快方法是什么?在这种情况下,这将是c(1,4),c(1,5),c(1,6),c(2,4),c(2,5)。。。c(3,5),c(3,6) 如何使用矢量化方法解决此问题?通常,mxn矩阵会有n^m这样的组合。您可以使用expand.grid函数获得每行元素的所有组合,如图所示,使用split构建行列表,并使用do.call函数将该列表的每个元素传递给expand.grid: (m <- rbind(1:3, 4:

我有一个
m
x
n
矩阵,如下所示:

1 2 3
4 5 6
按行获取所有可能组合的最快方法是什么?在这种情况下,这将是
c(1,4),c(1,5),c(1,6),c(2,4),c(2,5)。。。c(3,5),c(3,6)


如何使用矢量化方法解决此问题?通常,
m
x
n
矩阵会有
n^m
这样的组合。

您可以使用
expand.grid
函数获得每行元素的所有组合,如图所示,使用
split
构建行列表,并使用
do.call
函数将该列表的每个元素传递给
expand.grid

(m <- rbind(1:3, 4:6))
#      [,1] [,2] [,3]
# [1,]    1    2    3
# [2,]    4    5    6
do.call(expand.grid, split(m, rep(1:nrow(m), ncol(m))))
#   1 2
# 1 1 4
# 2 2 4
# 3 3 4
# 4 1 5
# 5 2 5
# 6 3 5
# 7 1 6
# 8 2 6
# 9 3 6
(m
expand.grid(拆分(m,行(m))
可能更简单
(m <- matrix(1:6, nrow=3))
#      [,1] [,2]
# [1,]    1    4
# [2,]    2    5
# [3,]    3    6
do.call(expand.grid, split(m, rep(1:nrow(m), ncol(m))))
#   1 2 3
# 1 1 2 3
# 2 4 2 3
# 3 1 5 3
# 4 4 5 3
# 5 1 2 6
# 6 4 2 6
# 7 1 5 6
# 8 4 5 6