2012-10-02 11 views

Odpowiedz

11

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] 
+0

To rozwiązanie i ksol używa: raczej niż, jaki wpływ będzie miało, jeśli później chcę powiązać zmienną/stałą z plikiem obrazu? – Jay

+0

i jak mogę nadać nazwę utworzonej tablicy? wiele thx – Jay

+0

'my_array = wartość.zip (razy) .flat_map {| v, t | [v] * t} ' –

3
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.

2

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 
+0

Jest coś do powiedzenia na temat prostoty. –

1
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"] 
1

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"] 
Powiązane problemy