Class: Lista::MD_list
Instance Attribute Summary collapse
-
#head ⇒ Object
Variable que almacena la nodo cabeza (primero) de la lista.
-
#tail ⇒ Object
Variable que almacena la nodo cola (final) de la lista.
Instance Method Summary collapse
-
#each ⇒ Object
Itera en la lista.
-
#extract_end ⇒ Object
Extrae el Ășltimo elemento de la lista.
-
#extract_first ⇒ Object
Extrae el primer nodo.
-
#initialize ⇒ MD_list
constructor
Inicializa la lista.
-
#insert(node) ⇒ Object
Inserta un nodo.
Constructor Details
#initialize ⇒ MD_list
Inicializa la lista
20 21 22 23 24 25 |
# File 'lib/dieta/lista.rb', line 20 def initialize() @head = nil @tail = nil end |
Instance Attribute Details
#head ⇒ Object
Variable que almacena la nodo cabeza (primero) de la lista
15 16 17 |
# File 'lib/dieta/lista.rb', line 15 def head @head end |
#tail ⇒ Object
Variable que almacena la nodo cola (final) de la lista
17 18 19 |
# File 'lib/dieta/lista.rb', line 17 def tail @tail end |
Instance Method Details
#each ⇒ Object
Itera en la lista
75 76 77 78 79 80 81 |
# File 'lib/dieta/lista.rb', line 75 def each i = @head; while i != nil yield i.value i = i.next end end |
#extract_end ⇒ Object
Extrae el Ășltimo elemento de la lista
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
# File 'lib/dieta/lista.rb', line 58 def extract_end nodo = @tail if nodo != nil if nodo.prev != nil @tail = nodo.prev @tail.next = nil else @head = nil @tail = nil end end nodo end |
#extract_first ⇒ Object
Extrae el primer nodo
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
# File 'lib/dieta/lista.rb', line 28 def extract_first nodo = @head if nodo != nil if nodo.next != nil @head = nodo.next else @head = nil @tail = nil end end nodo end |
#insert(node) ⇒ Object
Inserta un nodo
47 48 49 50 51 52 53 54 55 |
# File 'lib/dieta/lista.rb', line 47 def insert(node) if @head == nil @head = node elsif node.prev = @tail @tail.next = node end @tail = node end |