-2

假设我们有一个具有这种形状的数组:[2, 5]。可能的索引组合是:

[
  [0, 0],
  [0, 1],
  [0, 2],
  [0, 3],
  [0, 4],
  [1, 0],
  [1, 1],
  [1, 2],
  [1, 3],
  [1, 4]
]

如果数组有n维度,是否有一种简单的方法可以在 Ruby 中生成索引?

4

4 回答 4

5

这应该有效:

def coordinates(first, *others)
  (0...first).to_a.product(*others.map { |to| (0...to).to_a })
end

coordinates(2, 5)
#=> [[0, 0], [0, 1], [0, 2], [0, 3], [0, 4],
#    [1, 0], [1, 1], [1, 2], [1, 3], [1, 4]]

coordinates(4, 3, 3)
#=> [[0, 0, 0], [0, 0, 1], [0, 0, 2],
#    [0, 1, 0], [0, 1, 1], [0, 1, 2],
#    [0, 2, 0], [0, 2, 1], [0, 2, 2],
#    [1, 0, 0], [1, 0, 1], [1, 0, 2],
#    [1, 1, 0], [1, 1, 1], [1, 1, 2],
#    [1, 2, 0], [1, 2, 1], [1, 2, 2],
#    [2, 0, 0], [2, 0, 1], [2, 0, 2],
#    [2, 1, 0], [2, 1, 1], [2, 1, 2],
#    [2, 2, 0], [2, 2, 1], [2, 2, 2],
#    [3, 0, 0], [3, 0, 1], [3, 0, 2],
#    [3, 1, 0], [3, 1, 1], [3, 1, 2],
#    [3, 2, 0], [3, 2, 1], [3, 2, 2]]
于 2013-09-19T12:55:30.147 回答
0

Not sure this is totally correct, but it should help you on the right track:

def combinations(dimensions)
  dimensions.inject([]){|total, dimension|
    dim = (0...dimension).to_a
    total.empty? ? dim : total.product(dim)
  }.map(&:flatten)
end

p combinations([2, 5]) #=> [[0, 0], [0, 1], [0, 2], [0, 3], [0, 4], [1, 0], [1, 1], [1, 2], [1, 3], [1, 4]]


p combinations([2, 2, 2]) #=> [[0, 0, 0], [0, 0, 1], [0, 1, 0], [0, 1, 1], [1, 0, 0], [1, 0, 1], [1, 1, 0], [1, 1, 1]]
于 2013-09-19T12:56:05.750 回答
0

尝试:

a = [[0,1],[0,1,2,3,4]]
res = a[0].product(a[1])
于 2013-09-19T13:00:38.980 回答
0

干得好。它可能不漂亮,但它似乎工作。

def gen_indices(dimensions, solutions = [], current=[], level = 0)
  if level < dimensions.length
    dimensions[level].times do |i|
      current << i
      if level == dimensions.length - 1
        solutions << current.clone
      else
        gen_indices(dimensions, solutions, current, level + 1)
      end
      current.pop
    end
  end
  solutions
end

p gen_indices([4,3,2])
于 2013-09-19T12:54:38.847 回答