Jaki jest sposób Ruby na osiągnięcie obserwowania?
a = [1,2]
b = [3,4]
Chcę tablicę:
=> [f(1,3) ,f(1,4) , f(2,3) ,f(2,4)]
Jaki jest sposób Ruby na osiągnięcie obserwowania?
a = [1,2]
b = [3,4]
Chcę tablicę:
=> [f(1,3) ,f(1,4) , f(2,3) ,f(2,4)]
Odpowiedzi:
Możesz użyć, product
aby najpierw uzyskać iloczyn kartezjański tablic, a następnie zebrać wyniki funkcji.
a.product(b) => [[1, 3], [1, 4], [2, 3], [2, 4]]
Możesz więc użyć map
lub, collect
aby uzyskać wyniki. Są to różne nazwy tej samej metody.
a.product(b).collect { |x, y| f(x, y) }
a.product(b,c)
i tak dalej (do wyczerpania pamięci). Ruby jest super!
a.map {|x| b.map {|y| f(x,y) } }.flatten
Uwaga: W wersji 1.8.7+ możesz dodać 1
jako argument spłaszczenia, aby nadal uzyskiwać poprawne wyniki po f
zwróceniu tablicy.
Oto abstrakcja dla dowolnej liczby tablic:
def combine_arrays(*arrays)
if arrays.empty?
yield
else
first, *rest = arrays
first.map do |x|
combine_arrays(*rest) {|*args| yield x, *args }
end.flatten
#.flatten(1)
end
end
combine_arrays([1,2,3],[3,4,5],[6,7,8]) do |x,y,z| x+y+z end
# => [10, 11, 12, 11, 12, 13, 12, 13, 14, 11, 12, 13, 12, 13, 14, 13, 14, 15, 12, 13, 14, 13, 14, 15, 14, 15, 16]
Aspekty mają, Array#product
które dają iloczyn krzyżowy tablic. Jest również aliasowany jak ** operator
dla przypadku dwóch tablic. Używając tego, wyglądałoby to tak:
require 'facets/array'
a = [1,2]
b = [3,4]
(a.product b).collect {|x, y| f(x, y)}
Jeśli używasz Ruby 1.9, product
jest wbudowana funkcja Array.
[a[0], b[0]]
i[a[1], b[1]]
. Nie obejmowałoby[a[0], b[1]]
.a.zip(b) => [[1,3],[2,4]]