mirror of
https://github.com/TheAlgorithms/Ruby
synced 2025-01-15 03:43:22 +01:00
74 lines
1.3 KiB
Ruby
74 lines
1.3 KiB
Ruby
# Define a node in the list
|
|
class Node
|
|
attr_accessor :value, :next
|
|
def initialize(value)
|
|
@value = value
|
|
@next = nil
|
|
end
|
|
end
|
|
|
|
# A Class for single linked lists (each element links to the next one, but not to the previous one)
|
|
|
|
class SingleList
|
|
include Enumerable
|
|
attr_accessor :head
|
|
def initialize
|
|
@head = nil
|
|
end
|
|
|
|
def insert_tail(value)
|
|
newNode = Node.new(value)
|
|
if @head.nil?
|
|
@head = newNode
|
|
else
|
|
tempNode = @head
|
|
tempNode = tempNode.next until tempNode.next.nil?
|
|
tempNode.next = newNode
|
|
end
|
|
end
|
|
|
|
def insert_head(value)
|
|
newNode = Node.new(value)
|
|
if @head.nil?
|
|
@head = newNode
|
|
else
|
|
newNode.next = @head
|
|
@head = newNode
|
|
end
|
|
end
|
|
|
|
def each
|
|
return if @head.nil?
|
|
|
|
current = @head
|
|
until current.nil?
|
|
yield current.value
|
|
current = current.next
|
|
end
|
|
end
|
|
|
|
def print_list
|
|
puts '[' + self.to_a.join(', ') + ']'
|
|
end
|
|
|
|
def delete_head
|
|
if !@head.nil? && !@head.next.nil?
|
|
newHead = @head.next
|
|
@head = newHead
|
|
elsif !@head.nil? && @head.next.nil?
|
|
@head = nil
|
|
end
|
|
end
|
|
|
|
def delete_tail
|
|
return if @head.nil?
|
|
|
|
tempNode = @head
|
|
tempNode = tempNode.next until tempNode.next.next.nil?
|
|
tempNode.next = nil
|
|
end
|
|
|
|
def empty?
|
|
@head.nil?
|
|
end
|
|
end
|