从带有ruby数字的数组生成图形路径

我有一个有12个节点的无向​​图。 在这个方法中:

def generate_paths arr = [] (1..10).each { arr << [rand(12)].product([rand(12)]) } arr end 

我生成一个这样的数组: arr = [[3, 12], [8, 12], [0, 3], [0, 5], [0, 10], [7, 9], [5, 5], [4, 9], [5, 12], [0, 1]]表示图形边缘。

我想在图表中找到最长的路径,例如每条边最多使用一次。 对于给定的示例,它将类似于: arr = [[1, 0], [0, 5], [5, 5], [5, 12], [12, 3], [3, 0], [0, 10]]

我通过搜索Euler路径,但用其他编程语言编写,已经在许多方面看到了解决这个问题的方法。 我将如何在Ruby中继续它?

目前还不清楚目标是什么。

我猜你正在尝试获取一个包含随机数的数组,其中任何给定数组的第二个数等于下一个数组的第一个数。

如果是这种情况,那么你可以使用each_cons轻松实现这一点, each_cons是“每个连续”的缩写,并且接受n的参数(即项目数)。

 random_numbers = 8.times.map { rand(12) } # => [1, 0, 5, 5, 12, 3, 0, 10] random_numbers.each_cons(2).to_a # => [[1, 0], [0, 5], [5, 5], [5, 12], [12, 3], [3, 0], [0, 10]]