我在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功能可以帮助解决这个问题?或者是递归执行此操作的唯一选择?
由于
答案 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]]