Class: List
Overview
Clase que define una lista doblemente enlazada formada por elementos ListNode
Instance Attribute Summary collapse
-
#head ⇒ ListNode
readonly
“puntero” al inicio de la lista.
-
#tail ⇒ ListNode
readonly
“puntero” al final de la lista.
Instance Method Summary collapse
- #[](i) ⇒ Object
- #each ⇒ Object
-
#headToTail ⇒ Array(ListNode)
Realiza un recorrido desde head hasta tail.
-
#initialize(nodo) ⇒ List
constructor
A new instance of List.
- #invertir ⇒ Object
-
#multiple_push(nodos) ⇒ Object
Inserta multiples elementos al final de la lista.
-
#pop ⇒ Object
Extrae un elemento del final de la lista.
-
#push(nodo) ⇒ Object
Inserta elementos al final de la lista.
- #tailToHead ⇒ Object
-
#vacia? ⇒ Boolean
Comprueba si la lista se encuentra vacia.
Constructor Details
Instance Attribute Details
#head ⇒ ListNode (readonly)
“puntero” al inicio de la lista
6 7 8 |
# File 'lib/simpleselect/list.rb', line 6 def head @head end |
#tail ⇒ ListNode (readonly)
“puntero” al final de la lista
6 7 8 |
# File 'lib/simpleselect/list.rb', line 6 def tail @tail end |
Instance Method Details
#[](i) ⇒ Object
78 79 80 |
# File 'lib/simpleselect/list.rb', line 78 def [] (i) headToTail[i] end |
#each ⇒ Object
75 76 77 |
# File 'lib/simpleselect/list.rb', line 75 def each headToTail.each{|i| yield i} end |
#headToTail ⇒ Array(ListNode)
Realiza un recorrido desde head hasta tail
57 58 59 60 61 62 63 64 65 |
# File 'lib/simpleselect/list.rb', line 57 def headToTail() val=[@head] nodo=@head while (nodo.next!=nil)do nodo=nodo.next val.push(nodo) end val end |
#invertir ⇒ Object
81 82 83 84 85 |
# File 'lib/simpleselect/list.rb', line 81 def invertir val = [] self.each {|i| val.unshift(i)} val end |
#multiple_push(nodos) ⇒ Object
Inserta multiples elementos al final de la lista
29 30 31 32 33 34 |
# File 'lib/simpleselect/list.rb', line 29 def multiple_push (nodos) nodos.each { |i| raise unless i.is_a? (ListNode) push(i) } end |
#pop ⇒ Object
Extrae un elemento del final de la lista
38 39 40 41 42 43 |
# File 'lib/simpleselect/list.rb', line 38 def pop aux = @head.value @head = @head.next @head.prev = nil aux end |
#push(nodo) ⇒ Object
Inserta elementos al final de la lista
18 19 20 21 22 23 24 |
# File 'lib/simpleselect/list.rb', line 18 def push (nodo) raise unless nodo.is_a? (ListNode) nodo.prev=@tail @tail.next=nodo @tail=nodo end |
#tailToHead ⇒ Object
66 67 68 69 70 71 72 73 74 |
# File 'lib/simpleselect/list.rb', line 66 def tailToHead() val=[@tail] nodo=@tail while (nodo.prev != nil)do nodo=nodo.prev val.push(nodo) end val end |
#vacia? ⇒ Boolean
Comprueba si la lista se encuentra vacia
47 48 49 50 51 52 53 |
# File 'lib/simpleselect/list.rb', line 47 def vacia? a = false if (@head == nil) a = true end a end |