从Ruby中的多维数组创建排列

时间:2011-04-07 14:10:16

标签: ruby arrays

我在Ruby中有以下多维数组:

[[1,2], [3], [4,5,6]]

我需要输出以下内容:

[[1,3,4], [1,3,5], [1,3,6], [2,3,4], [2,3,5], [2,3,6]]

我尝试过创建一个递归函数,但我没有太多运气。

是否有任何Ruby功能可以帮助解决这个问题?或者是递归执行此操作的唯一选择?

由于

1 个答案:

答案 0 :(得分:31)

是的,Array#product就是这样做的(Cartesian product):

a = [[1,2], [3], [4,5,6]]
head, *rest = a # head = [1,2], rest = [[3], [4,5,6]]
head.product(*rest)
#=> [[1, 3, 4], [1, 3, 5], [1, 3, 6], [2, 3, 4], [2, 3, 5], [2, 3, 6]] 

另一种变体:

a.inject(&:product).map(&:flatten)
#=> [[1, 3, 4], [1, 3, 5], [1, 3, 6], [2, 3, 4], [2, 3, 5], [2, 3, 6]]