2013-04-05 3 views
7
# this code works 
list = (0..20).to_a 
# => [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20] 

odd = list.select { |x| x.odd? } 
# => [1, 3, 5, 7, 9, 11, 13, 15, 17, 19] 

list.reject! { |x| x.odd? } 
# => [0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20] 

# but can i emulate this type of functionality with an enumerable method? 
set = [1,5,10] 
# => [1, 5, 10] 
one, five, ten = set 
# => [1, 5, 10] 
one 
# => 1 
five 
# => 5 
ten 
# => 10 

# ------------------------------------------------ 
# method I am looking for ? 
list = (0..20).to_a 
odd, even = list.select_with_reject { |x| x.odd? } 
# put the matching items into the first variable 
# and the non-matching into the second 
+0

Zbudowany w metodach są ładne, ale jesteś w przeciwieństwie do dodawania własnych metody do "Tablicy", która to zrobi? – MrDanA

+0

tak, myślałem o tym, że małpa łata Arraya, aby go dodać - wygląda na to, że coś, co Ruby mógł już wbudować, ale nic nie zobaczyło w dokumentach: – house9

Odpowiedz

11

Oczywiście, można zrobić:

odd, even = list.partition &:odd? 
+0

niesamowite - dziękuję; ciekawe, pojawia się na przeliczalnych dokumentach - http://ruby-doc.org/core-1.9.2/Enumerable.html, ale nie na tablicy? – house9

+1

@ house9 Enumerable to mixin, więc wiele klas może z niego korzystać. Hashe też z nich korzystają. – MrDanA

+0

Dzieje się tak dlatego, że jest zdefiniowany w "Zmiennej", ale nie w "Tablicy". Nazywa się to * dziedziczeniem * i jest jedną z podstawowych koncepcji Ruby i wielu innych języków, nie tylko tych zorientowanych obiektowo. –

1
odd = [] 
even = [] 
list = [1..20] 
list.each {|x| x.odd? ? odd << x : even << x } 
0

Jak pguardiario powiedział, metoda partition jest najbardziej bezpośredni sposób . Można również użyć Set#divide:

require 'set' 
list = (1..10).to_a 
odd, even = Set.new(list).divide(&:odd?).to_a.map{|x| x.to_a} 
0

można spróbować poniżej:

odd,even = (0..20).group_by(&:odd?).values 
p odd,even 

wyjściowa:

[0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20] 
[1, 3, 5, 7, 9, 11, 13, 15, 17, 19] 
Powiązane problemy