jak można buit tablicy z dwóch tablic następujące:tworząc tablicę informacji zawartych w dwóch układach
nazwa = [a, b, c]
how_many_of_each [3, 5, 2]
uzyskać
my_array = [a, a, a, b, b, b, b, b, C, C]
jak można buit tablicy z dwóch tablic następujące:tworząc tablicę informacji zawartych w dwóch układach
nazwa = [a, b, c]
how_many_of_each [3, 5, 2]
uzyskać
my_array = [a, a, a, b, b, b, b, b, C, C]
Zastosowanie zip
, flat_map
i tablica mnożenie
irb(main):001:0> value = [:a, :b, :c]
=> [:a, :b, :c]
irb(main):002:0> times = [3, 5, 2]
=> [3, 5, 2]
irb(main):003:0> value.zip(times).flat_map { |v, t| [v] * t }
=> [:a, :a, :a, :b, :b, :b, :b, :b, :c, :c]
name.zip(how_many_of_each).inject([]) do |memo, (x, y)|
y.times { memo << x}
memo
end
=> [:a, :a, :a, :b, :b, :b, :b, :b, :c, :c]
EDIT: No dobrze, lepiej patrz @David Grayson.
to zrobi to w łatwy do zrozumienia sposób:
my_array = []
name.count.times do |i|
how_many_of_each[i].times { my_array << name[i] }
end
Jest coś do powiedzenia na temat prostoty. –
array = ["a", "b", "c"]
how_many = [2, 2, 2]
result = []
array.each_with_index do |item, index|
how_many[index].times { result << item }
end
print result # => ["a", "a", "b", "b", "c", "c"]
można wybrać ten, który chcesz (wystarczy zamienić komentarz #
):
class Array
def multiply_times(how_many)
r = []
#how_many.length.times { |i| how_many[i].times { r << self[i] } }
self.each_with_index { |e, i| how_many[i].times { r << e } }
r
end
end
p ['a', 'b', 'c'].multiply_times([3, 5, 2])
#=> ["a", "a", "a", "b", "b", "b", "b", "b", "c", "c"]
to było fajne Ćwicz dla siebie. Dzięki. – Agis