从Ruby中的列表中获取对的所有组合

时间:2009-10-15 15:13:04

标签: arrays ruby combinations

我有一个元素列表(例如数字),我想检索所有可能对的列表。我怎么能用Ruby做到这一点?

示例:

l1 = [1, 2, 3, 4, 5]

结果:

l2 #=> [[1,2], [1,3], [1,4], [1,5], [2,3], [2,4], [2,5], [3,4], [3,5], [4,5]]

2 个答案:

答案 0 :(得分:28)

在Ruby 1.8.6中,您可以使用Facets

require 'facets/array/combination'
i1 = [1,2,3,4,5]
i2 = []
i1.combination(2).to_a # => [[1, 2], [1, 3], [1, 4], [1, 5], [2, 3], [2, 4], [2, 5], [3, 4], [3, 5], [4, 5]]

在1.8.7及更高版本中,combination是内置的:

i1 = [1,2,3,4,5]
i2 = i1.combination(2).to_a

答案 1 :(得分:8)

或者,如果你真的想要一个非图书馆的答案:

i1 = [1,2,3,4,5]
i2 = (0...(i1.size-1)).inject([]) {|pairs,x| pairs += ((x+1)...i1.size).map {|y| [i1[x],i1[y]]}}