Class: DSA::Queue
- Inherits:
-
Object
- Object
- DSA::Queue
- Defined in:
- lib/dsa-ruby/queue.rb
Instance Method Summary collapse
- #dequeue ⇒ Object
- #empty? ⇒ Boolean
- #enqueue(val) ⇒ Object
-
#initialize ⇒ Queue
constructor
A new instance of Queue.
- #peek ⇒ Object
- #size ⇒ Object
- #to_a ⇒ Object
Constructor Details
#initialize ⇒ Queue
Returns a new instance of Queue.
3 4 5 |
# File 'lib/dsa-ruby/queue.rb', line 3 def initialize @elements = [] end |
Instance Method Details
#dequeue ⇒ Object
12 13 14 15 |
# File 'lib/dsa-ruby/queue.rb', line 12 def dequeue raise IndexError, "queue is empty" if empty? @elements.shift end |
#empty? ⇒ Boolean
26 27 28 |
# File 'lib/dsa-ruby/queue.rb', line 26 def empty? @elements.empty? end |
#enqueue(val) ⇒ Object
7 8 9 10 |
# File 'lib/dsa-ruby/queue.rb', line 7 def enqueue(val) @elements.push(val) self end |
#peek ⇒ Object
17 18 19 20 |
# File 'lib/dsa-ruby/queue.rb', line 17 def peek raise IndexError, "queue is empty" if empty? @elements.first end |
#size ⇒ Object
22 23 24 |
# File 'lib/dsa-ruby/queue.rb', line 22 def size @elements.size end |
#to_a ⇒ Object
30 31 32 |
# File 'lib/dsa-ruby/queue.rb', line 30 def to_a @elements.dup end |