2013-03-28 2 views
19

Nun, dies das Array,Ruby-Array-Zugriff 2 aufeinanderfolgende (verkettet) Elemente zu einer Zeit

[1,2,3,4,5,6,7,8,9] 

Ich möchte,

[1,2],[2,3],[3,4] upto [8,9] 

Als ich tun, each_slice (2) I erhalten,

[[1,2],[3,4]..[8,9]] 

Im derzeit dies zu tun,

arr.each_with_index do |i,j| 
    p [i,arr[j+1]].compact #During your arr.size is a odd number, remove nil. 
end 

Gibt es einen besseren Weg ??

+0

möglich Duplikat [Gibt es ein Algorithmus Wert in Duetten aus einem Array zu extrahieren und bedienen über sie?] (http://stackoverflow.com/questions/6075266/is-there-an-algorithm-to-extract-values-in-duets-from-an-array-and-operate-over) – jvnill

Antwort

30

Rubin liest Kopf. Sie wollen Nachteile Executive Elemente?

[1, 2, 3, 4, 5, 6, 7, 8, 9].each_cons(2).to_a 
# => [[1, 2], [2, 3], [3, 4], [4, 5], [5, 6], [6, 7], [7, 8], [8, 9]] 
+2

Gosh, Ich liebe Ruby. –

4

.each_cons macht genau das, was Sie wollen.

[1] pry(main)> a = [1,2,3,4,5,6,7,8,9] 
=> [1, 2, 3, 4, 5, 6, 7, 8, 9] 
[2] pry(main)> a.each_cons(2).to_a 
=> [[1, 2], [2, 3], [3, 4], [4, 5], [5, 6], [6, 7], [7, 8], [8, 9]] 
5

Du hast es fast richtig :)

arr = [1,2,3,4,5,6,7,8,9] 
arr.each_cons(2) do |chunk| 
    p chunk 
end 
# >> [1, 2] 
# >> [2, 3] 
# >> [3, 4] 
# >> [4, 5] 
# >> [5, 6] 
# >> [6, 7] 
# >> [7, 8] 
# >> [8, 9] 
0

Und wenn Sie wollen Ihren eigenen each_cons implementieren:

arr = [1, 2, 3, 4, 5, 6, 7, 8, 9] 
cons = 2 

0.upto(arr.size - cons) do |i| 
    p arr[i, cons] 
end 

Ausgang:

[1, 2] 
[2, 3] 
[3, 4] 
[4, 5] 
[5, 6] 
[6, 7] 
[7, 8] 
[8, 9]