Open In App

Queue in Scala

Last Updated : 15 Oct, 2019
Improve
Improve
Like Article
Like
Save
Share
Report

A queue is a first-in, first-out (FIFO) data structure. Scala offers both an immutable queue and a mutable queue. A mutable queue can be updated or extended in place. It means one can change, add, or remove elements of a queue as a side effect. Immutable queue, by contrast, never change.

In Scala, Queue is implemented as a pair of lists. One is used to insert the elements and second to contain deleted elements. Elements are added to the first list and removed from the second list. The two most basic operations of Queue are Enqueue and Dequeue.

  • Enqueue – Adding an element at the end of the queue.
  • Dequeue – Deleting an element from the beginning of the queue.

Methods in Queue:

  1. +=: This method is used to add a single element in the end of the queue.
  2. ++=: This method is used to Insert more than one the element in the end of the queue.
  3. clear: Remove all elements from the queue.
  4. dequeue: Returns the first element in the queue
  5. enqueue: Adds all the elements to the queue.
  6. equals: Checks if two queues are structurally identical.
  7. front: Returns the first element in the queue.
  8. isEmpty: Check if the queue is empty or not.

Below are simple Scala programs to demonstrate these operations:

Example 1:




// Scala program for illustrating Queue
  
// Import Queue 
import scala.collection.mutable._
  
// Creating object
object GfG
    // Main method
    def main(args:Array[String])
    {
        // Initialize a queue
        var q1 = Queue(1, 2, 3, 4, 5)
          
        // Print the elements of queue
        print("Queue Elements: ")
        q1.foreach((element:Int) => print(element+" ")) 
          
        // Print the first element of the queue
        var firstElement = q1.front 
        println("\nFirst element in the queue: "+ firstElement) 
          
        // Enqueue 10 in the queue
        q1.enqueue(10
          
        // Print the elements of queue
        print("Queue Elements after enqueue: "
        q1.foreach((element:Int) => print(element+" "))
          
        // Dequeue first element from the queue
        var deq = q1.dequeue
          
        // Print the elements of queue
        print("\nQueue Elements after dequeue: "
        q1.foreach((element:Int) => print(element+" "))
          
        // Print the Dequeued element
        print("\nDequeued element: " + deq)
          
        // using isEmpty method
        println("\nQueue is empty: "+ q1.isEmpty)
    }
}


Output:

Queue Elements: 1 2 3 4 5 
First element in the queue: 1
Queue Elements after enqueue: 1 2 3 4 5 10 
Queue Elements after dequeue: 2 3 4 5 10 
Dequeued element: 1
Queue is empty: false

Example 2:




// Scala program for illustrating Queue
  
// Import Queue 
import scala.collection.mutable._
  
// Creating object
object GfG
    // Main method
    def main(args:Array[String])
    {
        // Initialize a queue
        var fruits = Queue[String]()
          
        // Adding elements to the queue
        fruits.enqueue("apple")
        fruits.enqueue("banana")
        fruits.enqueue("mango")
        fruits.enqueue("guava")
          
        // Print the elements of queue
        print("Queue Elements: ")
        fruits.foreach((element:String) => print(element+" ")) 
          
        // Print the first element of the queue
        var firstElement = fruits.front 
        println("\nFirst element in the queue: "+ firstElement) 
          
        // Enqueue pineapple in the queue
        fruits.enqueue("pineapple"
          
        // Print the elements of queue
        print("Queue Elements after enqueue: "
        fruits.foreach((element:String) => print(element+" "))
          
        // Dequeue first element from the queue
        var deq = fruits.dequeue
          
        // Print the elements of queue
        print("\nQueue Elements after dequeue: "
        fruits.foreach((element:String) => print(element+" "))
          
        // Print the Dequeued element
        print("\nDequeued element: " + deq)
  
        // Using clear method
        println("\nclear the queue: "+ fruits.clear)
          
        // Using isEmpty method
        println("\nqueue is empty: "+ fruits.isEmpty)
          
    }
}


Output:

Queue Elements: apple banana mango guava 
First element in the queue: apple
Queue Elements after enqueue: apple banana mango guava pineapple 
Queue Elements after dequeue: banana mango guava pineapple 
Dequeued element: apple
clear the queue: ()

queue is empty:true


Previous Article
Next Article

Similar Reads

Scala Queue take() method with example
The take() method is utilized to return a queue consisting of the first ‘n’ elements of the queue. Method Definition: def take(n: Int): Queue[A] Return Type: It returns a queue consisting of the first ‘n’ elements of the queue. Example #1: // Scala program of take() // method // Import Queue import scala.collection.mutable._ // Creating object obje
1 min read
Scala Queue count() method with example
The count() method is utilized to count the number of elements in the queue that satisfies a given predicate. Method Definition: def count(p: (A) => Boolean): Int Return Type: It returns the count the number of elements in the queue that satisfies a given predicate. Example #1: // Scala program of count() // method // Import Queue import scala.c
2 min read
Scala Queue copyToArray() method with example
The copyToArray() method is utilized in copying the elements of the queue to an Array. Method Definition: def copyToArray[B >: A](xs: Array[B], start: Int, len: Int): Int Parameters: xs: It denotes the array where elements are copied. start: It denotes the starting index for the copy to takes place. Its default value is 0. len: It denotes the nu
2 min read
Scala Queue contains() method with example
The contains() method is utilized to test if an element is present in the queue or not. Method Definition: def contains[A1 >: A](elem: A1): Boolean Return Type: It returns true if the element is present in the queue, else it returns false. Example #1: // Scala program of contains() // method // Import Queue import scala.collection.mutable._ // C
1 min read
Scala Queue clone() method with example
The clone() method is used to create a copy of the given queue. Method Definition: defclone(): Queue[A] Return Type: It return a new queue which is a copy of the given queue. Example #1: // Scala program of clone() // method // Import Queue import scala.collection.mutable._ // Creating object object GfG { // Main method def main(args:Array[String])
1 min read
Scala Queue clear() method with example
The clear() method is utilized to delete all the elements of the queue. Method Definition: def clear(): Unit Return Type: It returns an empty queue. Example #1: // Scala program of clear() // method // Import Queue import scala.collection.mutable._ // Creating object object GfG { // Main method def main(args:Array[String]) { // Creating a queue val
1 min read
Scala Queue apply() method with example
The apply() method is utilized to find the element at any given index in a queue. Method Definition: def apply(idx: Int): A Return Type: It returns the element at the given index of the queue. Example #1: // Scala program of apply() // method // Import Queue import scala.collection.mutable._ // Creating object object GfG { // Main method def main(a
1 min read
Scala Queue :+() method with example
The :+() method is utilized to return a new queue with an element added at the back of the given queue. Method Definition: def:+[B >: A](elem: B): Queue[B] Return Type: It returns a new queue with an element added at the back of the given queue. Example #1: // Scala program of :+() // method // Import Queue import scala.collection.mutable._ // C
1 min read
Scala Queue ++=() method with example
The ++=() method is utilized to add element of a queue at the back of another queue. Method Definition: def ++=(xs: IterableOnce[A]): Queue.this.type Return Type: It returns the given queue with elements of another queue added at its end. Example #1: // Scala program of ++=() // method // Import Queue import scala.collection.mutable._ // Creating o
1 min read
Scala Queue +=:() method with example
The +=:() method is utilized to add an element at the front of a queue. Method Definition: def +=:(elem: A): Queue.this.type Return Type: It returns the given queue with an element added at its front. Example #1: // Scala program of +=:() // method // Import Queue import scala.collection.mutable._ // Creating object object GfG { // Main method def
1 min read
Article Tags :