2017-10-03 15:06:15 +02:00
|
|
|
# Define a node in the list
|
|
|
|
class Node
|
|
|
|
attr_accessor :value, :next, :prev
|
|
|
|
def initialize(value)
|
|
|
|
@value = value
|
|
|
|
@next = nil
|
|
|
|
@prev = nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# A Class for double linked lists (each element links to the next one, and to the previous one)
|
|
|
|
class DoubleList
|
2020-10-12 18:59:48 +02:00
|
|
|
include Enumerable
|
2017-10-03 15:06:15 +02:00
|
|
|
attr_accessor :head, :tail
|
2020-10-12 18:59:48 +02:00
|
|
|
def initialize
|
2017-10-03 15:06:15 +02:00
|
|
|
@head = nil
|
|
|
|
@tail = nil
|
|
|
|
end
|
|
|
|
|
|
|
|
def insert_tail(value)
|
|
|
|
new_node = Node.new(value)
|
2020-10-12 18:59:48 +02:00
|
|
|
if @head.nil?
|
2017-10-03 15:06:15 +02:00
|
|
|
@head = new_node
|
|
|
|
@tail = new_node
|
|
|
|
else
|
|
|
|
@tail.next = new_node
|
|
|
|
new_node.prev = @tail
|
|
|
|
@tail = new_node
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def insert_head(value)
|
|
|
|
new_node = Node.new(value)
|
2020-10-12 18:59:48 +02:00
|
|
|
if @head.nil?
|
2017-10-03 15:06:15 +02:00
|
|
|
@head = new_node
|
|
|
|
@tail = new_node
|
|
|
|
else
|
|
|
|
new_node.next = @head
|
|
|
|
@head.prev = new_node
|
|
|
|
@head = new_node
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-10-12 18:59:48 +02:00
|
|
|
def delete_tail
|
|
|
|
until @tail.nil?
|
2017-10-03 15:06:15 +02:00
|
|
|
@tail = @tail.prev
|
2020-10-12 18:59:48 +02:00
|
|
|
@tail.next = nil unless @tail.nil?
|
2017-10-03 15:06:15 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-10-12 18:59:48 +02:00
|
|
|
def delete_head
|
|
|
|
until @head.nil?
|
2017-10-03 15:06:15 +02:00
|
|
|
@head = @head.next
|
2020-10-12 18:59:48 +02:00
|
|
|
@head.prev = nil unless @head.nil?
|
2017-10-03 15:06:15 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-10-12 18:59:48 +02:00
|
|
|
def each
|
|
|
|
return if @head.nil?
|
|
|
|
|
|
|
|
current = @head
|
|
|
|
until current.nil?
|
|
|
|
yield current.value
|
|
|
|
current = current.next
|
2017-10-03 15:06:15 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-10-12 18:59:48 +02:00
|
|
|
def print_list
|
|
|
|
# the to_a method is from Enumerable, will call each to get the values, and return an array
|
|
|
|
puts '[' + self.to_a.join(', ') + ']'
|
|
|
|
end
|
|
|
|
|
|
|
|
def empty?
|
|
|
|
@head.nil?
|
2017-10-03 15:06:15 +02:00
|
|
|
end
|
2020-10-12 18:59:48 +02:00
|
|
|
end
|